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1.0 INTRODUCTION 


The WD10C01 is a VLSI Winchester/Optical Disk 
Controller chip that provides the data handling 
and control for intelligent disk applications. The 
WD10C01 interfaces to nearly any serial disk in- 
terface, including ST412, ST412HP, ESDI, SMD, 
and many optical disk interfaces. The WD10C01 
provides great flexibility in format design, allowing 
for multiple ID fields, special synchronization re- 
quirements, special information fields, or almost 
any other special requirement. The WD10C01 can 
provide all of the data, status, and control signals 
required by these interfaces. 


1.1 FEATURES 


¢ Disk interfaces and formats supported include 

ST412, ST412HP, ESDI, SMD and optical disks 

Full multi-sector operation with four byte ID 

auto-increment 

¢ Up to 24 mbit/second maximum transfer rate 

Supports 16-bit CRC-CCITT polynomial on ID 

field 

¢ Degree 5 and 6 Reed-Solomon ECC with 3- or 
5-way interleave to protect data field against 
long error burst 

¢ Provides composite syndromes for error 
correction 

¢ Up to 1:1 interleave operation 

Writeable control store allows flexible error 

Recovery, including redundant ID and sync 

fields 

Support hard or soft sector formats, sector size 


to 1250 bytes when 5-way interleave is used 
for degree 5 Reed-Solomon code 





PINNO 11D 


wD10C01 





FIGURE 1-1. 68-PIN PLCC 


Built in crystal driver for data rate and/or CPU 
use 


Generic non-multiplexed CPU interface with 
maskable interrupts 


Separate CPU and disk data busses 
On-the-fly compare against buffer data 
20 general I/O Lines for disk drive control 
68-Pin PLCC package 
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2.0 GENERAL DESCRIPTION 


The WD10C01 has separate ports for data DMA 
transfer and for the microprocessor to achieve a 
maximum performance. 


The WD10C01 performs the disk data serializa- 
tion and de-serialization. It can interface with 
various magnetic and optical Data En- 
coder/Decoders (ENDEC). The data format on the 
disk is controlled by a Writeable Control Store. It 
is very flexible with the capability to support 
various formats including optical disk. The device 
also has the capability to compare data and verify 
the ECC. The WD10C01 can perform full track 
operations without CPU intervention using the 
Writeable Control Store, auto-incrementing ID 
registers and the sector counter. 


The WD10C01 includes logic implementing 
CCITT-CRC and Reed-Solomon ECC for data 
protection. The ID field is protected by sixteen bit 
CRC and the data field is protected by degree five 
or six RS-ECC. The user can also select the inter- 
leave factor of three or five for the data field. The 
term "interleave" here should not be confused 
with the term "sector interleave," which defines 
the relation between the physical and the logical 
location of sectors within a track. Interleaving the 
data field means spreading the data across 
several ECC code words to improve the capability 
for correcting longer error bursts. 


For the error correction, the WD10C01 generates 
the composite syndromes. From this error infor- 
mation, the correction software can generate in- 
dividual syndromes to correct up to two error 
bytes per interleave (for degree 5) or up to three 
error bytes per interleave (for degree 6). Optional- 
ly, the user can use external, more powerful ECC 
device, such as WD60C80. 


GENERAL DESCRIPTION 


The highly programmable nature of the WD10C01 
allows the use of redundant ID and data sync 
fields within a single sector. This feature, along 
with the programmable degree 5 or 6 RS-ECC, 
gives the WD10C01 a greater capability for 
recovering user data in a sector with ‘grown’ 
defects. 


The WD10C01 interfaces to the buffer manager, 
such as WD60C40 through an eight bit DMA port. 
It uses asynchronous protocol through 
DREQ/DACK signals. 





The WD10C01 has a generic microprocessor in- 
terface that allows the WD10C01 to be used with 
all popular 8-bit microprocessors. The WD10C01 
has interrupt capability, which frees up the 
microprocessor from constantly polling the device 
status. The WD10C01 also has a built-in crystal 
oscillator driver that can be used to generate data 
reference, buffer management, or microprocessor 
clocks. Two separate outputs are provided with 
internal programmable dividers. Both outputs 
have the extra drive voltage and current neces- 
sary for driving MOS microprocessor clock inputs. 


The WD10C01 has 20 lines dedicated to external 
I/O ports that the microprocessor can use to con- 
trol the drive and head select lines, seek com- 
mand and drive status. Eight lines are output only, 
six lines are input only, and four other lines can be 
individually programmed for input or output. Two 
other latch and hold input lines are tied to the 
interrupt logic and can be used to detect fault and 
ready conditions without constantly polling the 
device. 
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4.0 SIGNAL DESCRIPTION 


The WD10C01 is a 68-pin PLCC device. I/O indicates that a signal is bidirectional. 
The following section describes the external sig- |,O indicates that a signal can be input 
nals available on the WD10C01. Conventions are output. 
as follows: 
* as a suffix indicates an active low signal; 
| indicates that a signal is an input to the however, most drawings and text use an 
WD10C01. overscore to indicate an active low signal. 


O indicates that a signal is an output from 
the WD10C01. 


| PIN | MNEMONIC DESCRIPTION 


a 21 — | -A4 CPU ADDRESS BUS. These signals are used to address internal 
WD10C01 registers. 


ee" CPU CLOCK OUTPUT. This is the OSC output (see below) 
divided by two or three, selected by an internal register. This out- 
put has extra drive for use with certain microprocessors. 
CHIP SELECT. This active low signal enables the WD10C01 bus 
interface logic. 


tween the CPU and the WD10C01. 
[> Sein ee a 
whenever an enabled interrupt condition occurs on the WD10C01. 
33 OSC OSCILLATOR OUTPUT. The 1x crystal oscillator output, optionally 
win divided by two. This signal has the same drive capability as 
CPUCLK. 
PO avo 
the WD10C01 on to the CPU data bus. 


61 RST RESET. This active low signal resets all internal circuits that must 
be reset at power on. A complete list is given later in this docu- 
ment. The reset is latched and the condition must be cleared by 

> |" | eee nee 
selected WD10C01 register from the CPU gala bus. 
LAO La EE cciibelstansinol 
clock. 
POE ee al 


| © | CRYSTAL DRIVER OUTPUT. 


TABLE 4-1. CPU INTERFACE 
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PIN | MNEMONIC | /O| DESCRIPTION, Cid 
ee i BUFFER DATA ACKNOWLEDGE. This active low signal indicates 
to the WD10C01 that data can now be transferred to or from the 
data buffer. 
interfaces the WD10C01 with the disk data buffer memory. 
Sel Ge Daly 8 ll 
parity with the disk data buffer memory. 
BUFFER DATA REQUEST. This signal is asserted when the 


WD10C01 has data to write to the data buffer, or needs data from 
the data buffer. 


TABLE 4-2. BUFFER INTERFACE 





















MNEMONIC | I/O| DESCRIPTION 
ADDRESS MARK DETECTED. Used only in ST412 type inter- 


PIN __ 
AMDET , I 
faces that use missing clocks or other qualifiers to the sync bytes 
that mark the start of a field. 
Cn ae 
byte (ST412) or soft sector mark ESDI, SMD) on the media. 


| NRZI NRZ READ DATA IN. Serial data input from the disk phase-locked 












loop. This signal is clocked in by the rising edge of RRCLK. 
NRZO O | NRZ WRITE DATA OUT. Serial data output. NRZO is valid on the 


rising edge of WRCLK. 
. 




















by the rising edge of this clock. 
SEQUENCER OUTPUT. This signal is a user definable output bit 
that is set up in the control byte of the sequencer control store 
(see below). This signal can be used to control an external ECC 


READ GATE. Active when reading from the disk drive. This signal 
is turned off for one byte time on an ID search error to reset exter- 
- if 
32 SEQOUT 
generator and checker, and is byte aligned with both read and 
write data. 


nal data decoders. 
-58 | WG | © | WRITE GATE. Active when writing to the disk drive. 


READ/REFERENCE CLOCK. This is the reference clock used to 
WRCLK WRITE CLOCK. This is output during write for drives that require 















set the data rate for write, and is the recovered clock for read. The 
Switching must be glitch free. NRZI is clocked into the WD10C01 
it. NRZO data is valid on the rising edge of this clock. 

TABLE 4-3. DISK DATA INTERFACE 
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MNEMONIC DESCRIPTION 


35 COMPLT COMPLETE. This signal is used to detect function complete condi- 
tions, such as seeks or status requests. The signal only generates 
~ _ if 


a CPU interrupt, and does not interfere with a read or write opera- 
— | 












tion. 
DRIVE FAULT. This signal is used to detect faults from the drive. 
The signal only generates a CPU interrupt, and does not interfere 
with a read or write operation. 
INDEX. This signal is used to indicate the start of a track. This sig- 
nal is latched for CPU status and interrupt. 


drive select and head select signals. 
mT PORT Y. This general purpose port is intended for use as other 
control outputs or inputs. Each bit is selectable as input or output, 
but all bits are initialized to input when the WD10C01 is reset. 
FB Nall LEE ella 
42-39 status signals. 
ew f SECTOR MARK. This signal is used for marking sector start loca- 


tions on the media. This can either be a hard sector mark, or a soft 
TABLE 4-4. DISK CONTROL INTERFACE 



































mark written on the media using AMENA (ESDI or SMD). 










PIN | MNEMONIC | VO| DESCRIPTION, 
ps2660.. VDD. <2 | aS VOUTS Da | 
}o4s i vss tt | GROUND, 


TABLE 4-5. DEVICE POWER 
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5.0 ARCHITECTURE 


The WD10C01 consists of the functional blocks 
shown in the block diagram in Figure 3-1. VDD 
and VSS are applied to the device through two 
separate pins each to improve noise immunity. 
The top and left hand sides of the diagram show 
CPU interface features, the right hand side shows 
disk interface features, and the bottom shows 
buffer interface features. These blocks are dis- 
cussed in the following paragraphs. 


The PORT DECODE block generates the 28 write 
strobes and 25 read strobes used by the 
microprocessor to access the various internal 
control and status ports. These include the inter- 
rupt registers, external disk control ports, control 
store, control store control, configuration, ECC 
control, and ID registers. 


The BUFFER CPU DATA block controls the trans- 
fer of data between the microprocessor and the 
internal registers. The direction control is qualified 
by chip select (CS) and read strobe (RD). 


The CPU CONFIGURATION PORTS are used to 
reset the WD10C01, set the address mark enable 
timing, set the buffer interface timing, and select 
the frequency of the clock outputs, OSC and 
CPUCLK. 


The OSCILLATORS AND DIVIDERS block 
generates the clock outputs, OSC and CPUCLK, 
using an external crystal (or clock input) and 
dividers to select the frequency. Frequency selec- 
tion is glitch free. 


The INTERRUPT STATUS AND MASK registers 
are used to check and mask interrupts. The mask 
register does not affect the status register inputs. 
The interrupt sources include index and sector 
mark, drive fault and operation complete, ECC er- 
rors, and internal event status. 


The EXTERNAL PORTS are used to generate 
control signals and read status with the disk drive. 
Eight bits are output, six are input, and four are 
individually programmable for either input or out- 
put. 


The CONTROL STORE consists of 32 words of 
28 bits that are used to program the format of the 
disk sector. The data source, field length, error 
handling and checksum selection, and control sig- 


nals, like Read Gate and Write Gate, are control- 
led by the data stored here. 


The CONTROL STORE CONTROL determines 
the next address in the control store to use, 
whether the next sequential address or a jump to 
another address. This block includes the sector 
counter used for multi-sector commands. This 
block also includes the BIT RING COUNTER, 
which determines the timing of data transfers in 
the WD10C01. 


The WAIT SEQUENCER handles searches for 
index, sector mark, address mark, and byte 
synchronization. 


The ID WRITE REGISTERS are 8 eight bit 
registers that are used to set the ID write field for 
format, or the search field for read/update write. 
Four of the registers are counters that auto-incre- 
ment during multi-sector commands. The other 
four registers do not increment, and are used for 
defect and flag information. The first byte of the 
four counters can be disabled for three byte ID 
fields. 


The ID READ REGISTERS are used to read the 
last ID read from the media to aid in defect han- 
dling. 


The ECD block performs the CRC on ID, selects 
the degree of RS-ECC with 3- or 5-way interleave 
on data fields, generates the checksum bytes, 
creates the composite syndromes and ECC error 
status necessary for the calculation of error loca- 
tion and mask. 


The VALUE register holds immediate data from 
the control store when generating gaps, sync 
fields, and address mark bytes. 


The SHIFT OUT register serializes internal or ex- 
ternal (buffer) data for writing on the disk. The 
output is multiplexed with the output of the check- 
sum register. 


The SHIFT IN register de-serializes the read data 
from the disk, clocked in by RRCLK. The data is 
also transferred to the checksum register for 
checking. 


The COMPARE block is used to compare incom- 
ing read data with an internal or external data 
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source. These include byte synchronization 
detection, ID field search, and buffer data com- 
pare. | 


The BUFFER INTERFACE handles the fetching 
and writing of data with the external data buffer. 
This includes parity generation and checking, and 
data handshake with the buffer controller. 


5.1 ERROR CORRECTION AND 
DETECTION CODES 


5.1.1. CCITT-CRC 


The WD10C01 protects the ID fields using the 
CCITT-CRC code. The polynomial is defined as 
follow: 


tee a4 


g(x) = yak 
The user can select the initial state of the shift 
registers to be either all zero’s or all one’s. 


5.1.2 Reed-Solomon ECC 


The data fields are protected using the interleaved 
Reed-Solomon code operating on 8 bits symbols. 
The redundancy bytes are inverted. WD10C01 
supports two polynomials of degree five and six. 
The generator polynomials operate in the finite 
field GF(256), which are defined as follow: 


Let 8' represent elements of a finite field defined 
by a polynomial over GF(2): 
g(x) = xP 4 x? 4 xP 4 x2 + a 


The elements of the finite field employed by the 
codes are: 


a! = ( pI 88. 


The generator polynomials are self reciprocal and 
defined as follows: 


1. Degree 5, distance 6: 


The coefficients of the polynomial in decimals are: 
1, 60, 183, 183, 60, 1. 


2. Degree 6, distance 7: 


be a | Nets Hees 


G(x) =(x+a X +a X +a X+a 


X+a X +a : 
( asl 120) 


The coefficients of the polynomial in decimals are: 
1, 176, 126, 163, 126, 176, 1. 


The calculated checkbytes are inverted before 
they are written into the disk. During read opera- 
tion, the WD10C01 computes the composite 
syndromes by recalculating the checkbytes for the 
data field being read and compare them against 
the checkbytes written on the disk. The individual 
syndromes can be computed by dividing the com- 
posite syndromes with the factors of the generator 
polynomial: 


Si(x) = R(x) MODULO Gi(x) 
where: 
| = 0..ecc degree -1. 
Si(x) =?th individual syndrome. 
R(x) = composite syndrome. 
Gi(x) = factor of the generator polynomial, 


(x+a). 


The WD10C01 supports two data interleaving fac- 
tors. The user can optimize the performance by 
choosing the right degree and interleave combina- 
tion. 


The following table shows the redundancy over- 
head and maximum field size. 





Interleave | Degree 


Factor | Overhead* | Max. Data* | Overhead’ | Max. Data* 
Field Size* Field Size* 













G(x) = (x+a259)* (x4a24)* 4-09) *(x4a")*(x+a2). 747 
1250 1245 
* all units — 
| 
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6.0 PROGRAMMING REFERENCE 


6.1 REGISTER ASSIGNMENTS ¢ configuration group 

The WD10C01 contains 32 output and 23 input ¢ device control group 

ports distributed in a 32 port address space, ¢ ID registers. 

selected by AO-A4, CS, and RD or WR. Address lines A4 and A3 select the group, and A2 


oe through AO select the register in the group. 
The ports are split into three functional groups: 







|RIW | Address | Assignment | R/W 
IW 
/W 









R 
R 
R 


RW | Address | __Assignment__|_R/W 
ECCP W R 
ECCS IW 


R/W 
R/W 
R/W 
R/W 
/W 
/W 
/W 
R/W 







= 











10010 SPORT 11010 R/W 
10011 11011 R/W 


10100 
11101 


10101 


W 
W 


2 


22 


ID1 
ID2 
ID3 
ID4 
ID5 

D7 


10110 TEST - do not use 11110 R/W 
10111 SKIP w 11111 R/W 





TABLE 6-1. REGISTER GROUPS 
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The following sections describe each register in 
detail. The use of the register is described in ae ncicales iene al < fas omy 
general and/or each bit is described. The table 
below defines how bit directions are defined in R/W indicates that the bit may be writ- 
these sections. Sometimes, a bit encoding is used ten and read 

to select a function that is not obvious from the aay 
definition of the bits involved. Refer to the section indicates that the bit may be read 


on Programming Notes for descriptions of these and cleared by writing a one to 
special modes. that bit 


; ; ra we C indicates that the bit may be 
ere table contains bit direction defini- ha cleared by writing a one to that bit 











2 | 
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oo | xtaue | XTAL6 
po | a | xTALe | XTALS | 
p14 fo | tal xa 
aft XTAL | XTAL 





6.3. CONFIGURATION GROUP 


The configuration group is used to do initial set up 
of ports and clocks, handle interrupts, and set up 
the control store memory. 





6.3.1 SRESET - Set Hardware Reset 
Register (00) 


Bits 7-1 are cleared to zero by reset. Bit 0 is set to 
one by an external reset. When writing one to 
SRST, any data on bits 7-1 are lost. 


REGISTER DEFINITION 


CLKDIV: CPUCLK divisor (see Note 1 below) 
OSCDIV: OSC divisor (see Note 1 below) 
Unused. 

Unused. 

Unused. 


ID3$4: select ID address size (see Note 2) 


SRST: hardware reset. This bit is set by an external reset 
on the RST input, or can be set by writing one to this bit. 
This bit must be set to zero before operating the WD10C01, 
or before setting any of the other bits in this register or any 
other register. 


ee 

Oo 

00 

Ee 
REQTIM: buffer request timing. When this bit is one, REQA 
is set at the same time that the internal buffer data holding 
register is ready. When this bit is zero, REQA occurs one 
RRCLK period early. This aids in interfacing to certain buff- 
er circuits that have a lag in their response times. 

po 





TABLE 6-2. SRESET - SET HARDWARE REGISTER (00) 


NOTE 1: The CPUCLK dividers are prescaled by 

the OSC dividers, as shown in the table below 

(XTAL is the clock generated by a crystal at X1 Two other considerations: 

and X2): ¢ CPUCLK = XTAL/3 will not be a 50% duty 
cycle unless XTAL is also a 50% duty cycle 

NOTE 2: The eight ID register bytes are split into clock. 


two fields: the first four are address, and auto-in- ° When resetting the WD10C01 under CPU 
crement for each sector; and the second four are = control, and the CPU is clocked by CPUCLK or 
flag bytes which do not increment. The ID3$4 bit OSC. set CPUDIV and OSCDIV back to zero 
selects whether 3 or 4 bytes of ID address bytes alore setting SRST. If this is not done, the 


will be used in the ID field. In 3 byte address . 
fields, register IDO is ignored. See Table 6-2A. clocks could glitch and cause the CPU to fail. 
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ID3$4 Address Counter Size | First Register In Field 


4bytes 


ID1 (IDO not used) 


TABLE 6-2A. ID REGISTER SELECTION 





6.3.2 SISR - Interrupt Status Register (01) 


The interrupt status register is designed to be 
used in interrupt or polled mode. The status is not 
affected by the interrupt mask register (see 
below). The interrupting condition has precedence 
over the CPU clear, which is performed by writing 


REGISTER ars DEFINITION 


PROGRAMMING REFERENCE 


a one to the selected interrupt bit. If the condition 
still exists, the clear will not be successful. The 
COMPLT and FAULT interrupts will stay set until 
the cause of the interrupt goes away. The ID- 
FULL, DXFER, SECEND, and SM$IX interrupts 
are generated by single bit time pulses that are 
triggered by the leading edge of the interrupt 
cause, and can therefore be cleared immediately. 
SEQSTP is a direct status signal and is cleared 
when the sequencer is executing a command. 


Before checking any bit (except SEQSTP), it 
should be cleared by writing a one to it. This 
register is not affected by reset. 


GINT - group interrupt. This is the state of the INT output, which is 
the logical OR of all of the enabled (by SIMR, see below) interrupt 
sources in this register. 


IDFULL - ID registers full. This interrupt is set at the end of any ID 
field access by the transition of the control store ID bit from true to 
false. This interrupt should be serviced before the next ID field is 
accessed. This interrupt can be cleared immediately. 


DXFER - data transfer started. This interrupt is set at the start of 
the data field by the transition of the control store BUFF or NOX- 
FER bit from false to true. This interrupt can be used to determine 
when it is safe to write to the LOOP, SKIP, SECCNT, or ID 
registers, if necessary. This interrupt can be cleared immediately. 


COMPLIT - complete. This interrupt is set in response to the COM- 
PLT input pin going true. This interrupt cannot be cleared until the 
COMPLT input pin goes false. 


SEQSTP - sequencer stopped. This interrupt is set when the se- 
quencer has stopped executing a command. This interrupt is 
cleared when the sequencer starts a new command. 


SECEND - sector end interrupt. This interrupt is set by the leading 
edge of the LAST bit in the control store (see below). This is used 
to signal the end of a sector for buffer management and other 
overhead processing. The size of the field in which the LAST bit is 
set can be adjusted to match the processing overhead to the end 
of the sector for maximum CPU performance; the minimum size 
for this field is two bytes. This interrupt can be cleared immediately. 


SM$IX - sector mark or index passed. This interrupt is set by the 
leading edge of the SECTOR or INDEX input going true, as 
selected by the mask in the sequencer control register (SEQCTL). 
RRCLK must be present for this interrupt to function. This interrupt 
can be cleared immediately. 





TABLE 6-3. SISR - INTERRUPT STATUS REGISTER 
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REGISTER | BIT | DIR | DEFINITION 
01 RIC 


waa FAULT - drive fault. This interrupt is set in response to the DRVFLT 


input pin going true. This interrupt cannot be cleared until the 
TABLE 6-3. SISR - INTERRUPT STATUS REGISTER (CONTINUED) 















DRVFLT input pin goes false. 








6.3.3 SIMR - Interrupt Mask Register (02) 


The interrupts listed are described in the SISR 
description. Writing a one to the mask bit enables 
the interrupt. The state of the mask bits does not 


affect the reading of status in SISR in any way. 
This register is cleared to zero by reset (interrupts 
disabled). Disabling GINT overrides any other 
enables set in this register. 













REGISTER | BIT | DIR _|_ DEFINITION 
GINT - enable all interrupts 
02, ~=~=——« BSS RWV___ | IDFULL- enable IDFULL interrupt 
RW 
roa 3 
Or = i 




















SM$IX - enable SM$IX interrupt 
R/W FAULT - enable FAULT interrupt 


TABLE 6-4. SIMR - INTERRUPT MASK REGISTER 
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6.3.4 SEQSTS - Sequencer Status (03) 


The following status bits are further clarified in used to check what sequencer operation is taking 
later registers and sections. These bits can be __ place. 


DEFINITION 

DATFLD - data field active. This bit means that the either 
the BUFF or the NOXFER bit is now active from the control 
store. 

ECCEN - checksum calculation active. The WD10C01 is 
now calculating the checksum. This status line usually en- 
compasses the ID or data field and checksum bytes, and is 
active during both read and write. 


LAST - The LAST bit is now active from the control store. 
ID - The ID bit is now active from the control store. 


CHK - The CHK bit is now active from the control store. 
The WD10C01 is now processing the checkbytes or 
syndromes for the CRC or ECC. 


WAIT - The wait sequencer is waiting for an event such as 
index, sector mark, address mark, or byte sync. 

AMDET - Address mark detect. This is the raw AMDET pin 
input. This pin can be used as an extra input bit in designs 
(such as ST506) that do not require this function. 
SEQOUT - The SEQOUT bit is now active from the control 
store. 





TABLE 6-5. SEQSTS - SEQUENCER STATUS REGISTER 
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6.3.5 PYC-PORT Y Configuration (03) 


This port is used to configure each port Y bit for reset, which causes all port Y pins to become 
input or output. This register is cleared to zero by __ inputs. 


DEFINITION 


PY3DIR - bit 3 direction: 0 = in; 1 = out 


PY2DIR - bit 2 direction: 0 = in; 1 = out 
PY1DIR - bit 1 direction: 0 = in; 1 = out 
PYODIR - bit 0 direction: 0 = in; 1 = out 


TABLE 6-6. PYC - PORT Y CONFIGURATION (03) 
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6.3.6 Control Store Windows 


The heart of the WD10C01 is its control store 
memory, which is organized as 32 instruction 
words of 28 bits each. Each 28 bit instruction is 
divided into three 8 bit parts: the control byte, the 
value byte, and the count byte; and one 4 bit part: 
the error control byte. The window registers are 
used to access these bytes. The control store ad- 
dress is specified by writing to the START 
register. Any write to a control store window 
register causes the START register to automat- 
ically increment to the next address to facilitate 
loading. 


2 


The contents of the control store are not affected 
by reset. 


6.3.6.1 CSERR - Control Store Error Control 
Byte Window (04) 


The transition of DAC from false to true, together 
with WG (in the control byte of the control store) 
or RCMP (read compare enable in the SEQCTL 
register), causes a one byte prefetch from the 
buffer. If an immediate fill character is used to 
specify the format data field or read compare byte 
(see below), and DAC is used to select the ECC 
for the data field, prefetch REQA signals are 
generated anyway. 


DEFINITION 


FAIL - Enable error failure. Setting this bit to one causes a 
command stop if an error is detected while executing the 
current control store instruction. The error can be 
CRC/ECC error, data miscompare error or a parity error 
during write operation. 


RTY - Enable read error retry. This bit is valid only during 
read. Setting this bit to one causes a sector retry (see 
below) if a read error is detected while executing the cur- 
rent control store instruction. An example of the use of this 
bit is to cause a retry on an ID field miscompare. 


DAC - Data field active. Set this bit to one when the current 
control store instruction involves a data field operation. 
This signal is used to select the data field checksum (RS- 
ECC) and to control data prefetch. When this bit is zero an 
ID field operation is assumed, and the ID field checksum 
(CRC) is selected. 


SEQOUT - user defined output. This is tied to the 
SEQOUT output pin through some delays which align the 
signal to the byte boundary of the read or write serial data. 
This output can be used to control an external ECC circuit, 
such as a Reed-Solomon code circuit. 


TABLE 6-7. CSERR-CONTROL STORE ERROR CONTROL BYTE WINDOW 
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6.3.6.2 CSCTL - Control Store Control Byte 
Window (05) 


REGISTER BIT | DIR | DEFINITION 


05 7 R/W SVSEL - value byte select. This bit selects the use of the 
value byte, which can be either immediate data (SVSEL = 
0) or a select for data source or destination (SVSEL = 1). 


05 R/W CWSEL - count byte select. The bit selects the use of the 
count byte, which can be either an immediate byte count 
(CWSEL = 0) or to specify an external condition to wait for 





(CWSEL = 1). 


WG - write gate output. This is tied directly to the WG out- 
put pin. 


05 4 R/W RG - read gate output. This is tied to the retry logic, which 
is then tied to the RG output pin. 

05 3 R/W AM - address mark enable output. This is tied to the AMC 
register (see below) which generates the AMENA signal. 


05 2 R/W CMPEN - compare enable. This signal is used to indicate 
that the bytes of the currently selected data source are to 
be compared with incoming serial data (ID, marker bytes, 
buffer data). 

SKPEN - jump to SKIP address at end of the current in- 


struction. This causes an absolute jump to the SKIP 
ais 


register address when the current contro! store instruction 
TABLE 6-8. CSCTL - CONTROL STORE BYTE WINDOW (05) 









is finished. Typically, this is used to set up a read and write 
program in the control store with a common ID search 
routine. (See later examples and SKIP register definition.) 


JMPEN - jump to LOOP address at end of the current in- 
struction. This causes a conditional jump to the LOOP 
register if the sector count (SECCNT) is not zero. If SEC- 
CNT is zero, the next sequential instruction is executed. 
Typically, this is used to specify the end of a sector, and 
tells the sequencer to go to the LOOP register address to 
operate on the next sector. 
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6.3.6.3 CSVAL - Control Store Value Byte 
Window (06) 


The use of the value byte depends on the state of 
the SVSEL bit of the control byte. When SVSEL is 
zero, the value byte specifies actual immediate 
data, like address mark, gap, and PLL sync bytes. 
When SVSEL is one, the value byte becomes an 
encoded bit field that enables the correct data 
source or destination. Both uses are shown 
below. 


To get large sector sizes, multiple control store 
instructions are used. For example, for a 1024 
byte sector size, use four instructions with 256 
byte count fields. With this scheme, the last in- 
struction must be flagged for error correction and 
write prefetch purposes. The LAST bit must be set 
with the BUFF or NOXFER bit to ensure proper 
operation. 


REGISTER | BIT | DIR | DEFINITION 
06 =—~«~“‘«~*S:S«Ss« SRW | VALLUE7-0 (actual value for field) 


TABLE 6-9. SVSEL of CONTROL BYTE ZERO 
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REGISTER a DEFINITION 


BUFF - data buffer. This bit causes data to be transferred 
to (disk read) or from (disk write or read compare) the disk 
data buffer. The leading edge of BUFF causes a decre- 
TT . 
The DAC bit in CSERR window selects the appropriate 
checksum automatically. 


ment of the SECCNT register, and increments the ID write 
TABLE 6-10. SVEL of CONTROL BYTE ONE 














register counters (see below). 


NOXFER - no data transfer. This bit is used when an 
ECC/CRC verify on the data field with no buffer data trans- 
fer is being performed. This bit is set INSTEAD of the 
BUFF bit, and affects the SECCNT and ID registers in the 
same way as the BUFF bit. 


LAST - last data buffer xfer control store instruction. Long 
data fields (greater than 256 bytes) are specified by using 
multiple control store instructions (2 for 512 bytes, 4 for 
1024 bytes, etc.). When the control store instruction is the 
last instruction of the data field specifiers, the LAST bit 
must be set to flag this. This only applies to data buffer 
transfers. LAST is set in ADDITION to BUFF or NOXFER. 
The CSCNT byte must be set to at least 01 when this bit is 
used. 


R/W ID - ID registers. On ID read, the incoming ID field 
from the disk is compared against the ID write registers 
and written at the same time to the ID read registers. On 
write (format), the data source is the ID write registers. 


CHK - checksum field. On read, this starts the check fora 
correct checksum. On write, this causes the checksum 
shift register to be gated into the NRZO data. In either 
case, the calculation is halted at the end of this instruction. 
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6.3.6.4 CSCNT - Control Store Count Byte specifies a condition to wait for before proceding. 
Window (07) Both uses are shown below. 


The use of the count byte depends on the state of 

the CWSEL bit of the control byte. When CWSEL [he count value is set to the actual number of 
is zero, the count byte specifies the actual length ee to rid ae aay Eas < denotes a 
of that field in bytes. When CWSEL is one, the Ne byte field, and FF a 256 byte field. 

count byte becomes an encoded bit field that 


TABLE 6-11. CWSEL of CONTROL BYTE ZERO 





REGISTER 


BIT 






DEFINITION 


WDAM - Wait for data address mark (ST412 ONLY). This 
bit causes the WD10C01 to pause until a data address 
mark is detected at the AMDET input. Bits 6-0 specify a 
timeout count that is the maximum number of byte times 
from the end of the ID field to the data address mark. The 
value field is used to specify the data pattern to compare 
against for byte sync. 
WIAM - Wait for ID address mark (ST412 ONLY). This bit 
causes the WD10C01 to pause until an ID address mark is 
detected at the AMDET input. The value field is used to 
specify the data pattern to compare against for byte sync. 



























R/W WIX - Wait for index. Pauses until index is detected at the 


INDEX input. 


WSM - Wait for sector mark. Pauses until sector mark is 
detected at the SECTOR input. 


STOP - Stop immediate. This bit causes the command se- 
quencer to immediately turn off all control outputs and 
return to the stopped state. 






R/W 









R/W 






“aT 
a - 





TABLE 6-12. CWSEL of CONTROL BYTE ONE 
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6.3.6.5 Wait Condition Sequences WIAM: 
The following sequences are performed on the ; 
above wait conditions to ensure proper error han- Wait for AMDET. Since ID address marks 
dling: could be found anywhere, there is no byte 
count, and the CPU must perform its own 
WDAM: timeout. However, after AMDET is 
detected, the sequencer waits sixteen bit 
Wait for AMDET. If the byte count is ex- times for the sync byte in the value byte to 
ceeded, a sync error is recorded, and (if be matched. The bit a oy 
the control store FAIL bit is set) the com- mented on each bit while the AMDET sig- 
mand halts. When AMDET is detected nal is active. If this bit count is exceeded, 
correctly, the sequencer waits sixteen bit this ee a sync error, and (if the 
times for the sync byte in the value byte to contro! store bit 2 set) a fauy. 1S: Der- 
be matched. The bit counter is decre- formed (ID retry Is discussed in a later 
mented on each bit while the AMDET sig- section). Checksum calculation starts 
nal is active. If this bit count is exceeded, when the is byte = detected, and the 
this is also a sync error. When a sync sync byte is included in the calculation. 
error occurs, the sequencer will stop or 
retry as defined by the control store FAIL WiXand WSM: 
and RTY bits. Checksum calculation starts ; 
when the sync byte is detected, and the Lb signal pac raetad Hear ian 
a ; on forever. The must perform its own 
sync byte is included in the calculation. SOUL ANG "=SnG HG KIELcbirie. ihe 
SEQCTL register to stop the command 
(see below). To do a wait for either index 
or sector mark (typical on hard sector 
drives), set both WIX and WSM. 
11/19/91 21-21 
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6.4 DEVICE CONTROL GROUP 


The device control group is used to set and read 
port X, Y, and Z bits for drive control. It is also 
used to execute data transfer commands with the 
sequencer, and correct ECC errors. 


6.4.1 PORTX - PORTX Output Bits (08) 


This register is cleared to zero by reset. The state 
of the output bits may be read back, allowing for 
read/modify/write operation. 


REGISTER | BIT | DIR | DEFINITION 
os 70 | RW _|_PX7-0 (direct to output pins) 


TABLE 6-13. PORTX OUTPUT BITS (08) 


6.4.2 PORTY - PORT Y I/O Bits (09) 


The direction of each bit is controlled by the Port 
Y Control Register (03). If a particular bit is set for 
input, then the state of the external pin is read by 
a read of this port. If the bit is set for output, then 
the last state written to that bit is read (Same as 
Port X). Writing to this register does not affect bits 
configured for input. Reset sets all bits to input, 
but does not affect the output latched data. 


REGISTER BIT | DIR | DEFINITION 
3-0 R/W PY3-0 (direct to I/O pins) 


TABLE 6-14. PORTY I/O BITS (09) 


6.4.3 PORTZ- PORT Z INPUT BITS (0A) 
REGISTER _| BIT | DIR | DEFINITION 
A | 5-0 | R | PZS5-0 (direct from input pins) 
TABLE 6-15, PORTZ INPUT BITS (0A) 


| 
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6.4.4 AMC - Address Mark Control (0A) are ordered backwards from the data bus num- 


The AMC register defines during which bit times Dering; |.e., writing 01 to this register will turn on 
the AMENA signal is active. When AM is set inthe  AMENA when bit 7 of the serial data stream is 
control store control byte of the current instruction,  2Ctive on NRZO. 

the AMENA signal will be active during the bit 

times specified in this register. This register is not 

affected by reset. Note that the bits in this register 


REGISTER BIT | DIR | DEFINITION 
Address mark bit control bit 0-7 


TABLE 6-16. AMC - ADDRESS MARK CONTROL (0A) 
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6.4.5 SEQCTL - Sequencer Control Register 
(0B) 


REGISTER BIT | DIR | DEFINITION 


7 W RGERLY - read gate early bit. This bit controls the timing 
of RG signal. If the bit is set to zero, the RG signal is ex- 
tended automatically until the ECC/CRC calculation is 
finished. Setting this bit to one will disable this feature. 

3 W IXMASK - index interrupt mask. This bit is used with the 
SMMASK bit to select the conditions for the SM$IX inter- 
rupt (see table below). 


OB ti“‘aC Hk: SMMASK - sector mark interrupt mask (see table below). 


1 Ww RCMP - enable read compare. This bit MUST be set when 
performing a read data compare command with the data 
buffer. It is used to change the buffer access from write buff- 
er to read buffer. 

W KILL - immediately kill the currently executing command. 
The sequencer will stop within three byte times. This bit 
must be asserted for at least 2 bytes time. 

5 


ECCERR - checksum error. An ECC or CRC error has 
been detected. This bit is valid when the sequencer is 
stopped. If the control bit IGNERR in ECCCTL is turned on, 
this status bit will always be zero and the sequencer will 
continue its operation ignoring the error condition. 


IDERR - ID checksum error. ACRC ID field error occurred 
during the previous ID field read. This condition is latched 
when a checksum error causes an ID retry, and is cleared 
at the start of the next ID field read (ID false to true transi- 
tion). 

OB 3 R PTYERR - parity error. A parity error during a transfer from 
the data buffer to the WD10C01 occurred during the pre- 
vious command. If FAIL bit is set in the current CS instruc- 
tion, the sequencer will stop its operation at the end of cur- 
rent instruction and WG output will be deasserted. This bit 
is valid only after the sequencer is stopped. 


SYNCER - sync search error. The search for a data field 


marker byte or sync byte failed. This bit is valid when the 
sequencer is stopped. 


a CMPERR - compare data error. A field that was compared 


iN 
es) 





against some specified data source compared incorrectly. 
This bit is valid when the sequencer is stopped. 


+7 


TABLE 6-17. SEQCTL - SEQUENCER CONTROL REGISTER (0B) 
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This register is not affected by reset. The IXMASK 
and SMMASK select the conditions for the SM$IX 
interrupt. Note that these mask bits are used to 
select only the source, and do not affect or enable 
the external interrupt signal. The table below 
defines the use of the SM$IX source mask bits: 







IXMASK SMS$IX set true on 


leading edge of: 
nothing 


0 SECTOR 
1 INDEX OR SECTOR 





| 








6.4.6 START - Sequencer Start Address (0C) 


The START register is not affected by reset. This 
register is actually two devices: the START hold- 
ing register, and the control store address counter. 
When the CPU writes to this port, the data bus 
value is latched into both the holding register and 
the address counter. The holding register is af- 
fected only by CPU writes, but the counter is in- 
cremented or reloaded by several different 
events. The START register is used for the follow- 
ing functions: 


1. The START register specifies the starting 
address in the control store for the pro- 
gram loaded there. When the CPU writes 
to the SECCNT register (see below), and 
the sequencer is stopped, the sequencer 
loads the contents of the holding register 
into the address counter and starts with 
the instruction at that location. 


2. Reading this port gives the current con- 
tents of the control store address counter. 
Reading the counter while the sequencer 
is running indicates which control store in- 
struction is currently being executed. It is 
recommended that the CPU ’debounce’ 
this port by reading the START register 
until the same value is read twice. This 
prevents erroneous values being read at 


REGISTER 


transition times. Reading the counter 
when the sequencer is stopped indicates 
where in the control store the condition 
causing the last halt occurred. This can be 
used to determine in which instruction an 
ECC or other fatal error occurred. 


3. The START register is used to specify the 
current address for control store window 
access. See control store windows above. 
The control store address counter is auto- 
matically incremented after any write to a 
control store window register (CSERR, 
CSCTL, CSVAL, or CSCNT). 


4. Writing to the START register clears error 
conditions. When a read error occurs, 
causing the command to halt (see FAIL bit 
in CSERR above), the error status is 
latched in the SEQCTL register. A write to 
the START register clears ECCERR, IOE- 
lI4E, CERR, EERR, SYNCER, CMPERR, 
and also PTYERR (which does not cause 
a halt). This must be performed prior to 
issuing any new commands. If SECCNT is 
non-zero, the sequencer will start as soon 
as the error is cleared. 


While the sequencer is running, the control store 
address counter is the program counter, and 
points at the current instruction being executed. 
The address in the counter can be changed by 
the following events during program execution: 


1. At the end of an instruction that has the 
SKPEN bit set, the address counter is 
loaded with the contents of the SKIP 
register. 


2. At the end of an instruction that has the 
JMPEN bit set, if the SECCNT register is 
not zero (i.e., more sectors to do), the ad- 
dress counter is loaded with the contents 
of the LOOP register. If SECCNT is zero, 
the address counter is incremented and 
the next sequential instruction is executed. 


ee 
START4-0 


TABLE 6-18. START - SEQUENCER START ADDRESS (0C) 





~ 
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3. If an instruction has the RTY bit set, and 
an error flag is currently set (ECCERR, 
CMPERR, or SYNCER), a retry occurs 
and the address counter is loaded with the 
contents of the LOOP register. 


4. lf a program halts due the STOP bit being 
set (i.e., the normal end of the program 
with SECCNT zero), and the CPU writes 
to the SECCNT register with more blocks 
to do before it detects the stopped condi- 
tion, the sequencer will restart using the 
current value of the START holding 
register. This prevents erroneous restarts 
from occurring. 


5. In all other cases, the control store address 
counter is incremented and the next se- 
quential instruction is executed. 





REGISTER BIT DIR 
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6.4.7 LOOP - Sequencer Loop Address (0D) 


The LOOP register specifies the address to set 
the START value to at the end of a control store 
instruction that has the JMPEN bit set in the con- 
trol byte. This also happens when an ID retry oc- 
curs (see below). The use of the LOOP register is 
based on the idea that all sector operations are 
sequential in nature, and that when the operation 
is complete, a single jump back to the start of the 
sequential sector operation is all that is needed. 
This register is not affected by reset. 


DEFINITION 
40 |W | LOOP4-0 (address to loop to in loop) 


TABLE 6-19. LOOP - SEQUENCER LOOP ADDRESS (0D) 
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6.4.8 ECCCTL- Error Correction Control 
Register (OE) 


CRCSET and ECCCLR must be set high and 
then low to complete the preset or clear operation. 
All bits in this register are cleared to zero upon 
reset time. 


DEFINITION 


ECCCLR - clear CRC and ECC shift register. Writing one 
to this register causes the CRC and ECC shift register to 
be held in the clear (all bits zero) state. The CPU must then 
write zero to this bit to complete the clear pulse. 


CRCSET - preset CRC shift register. Writing one to this 
register causes the CRC shift register to be held in the 

preset (all bits one) state. The CPU must then write zero to 
this bit to complete the preset pulse. 


CRCNIT - CRC shift register initial state. This bit selects 
whether to start the CRC shift register with all zeros 
(CRCNIT = 0) or all ones (CRCNIT = 1) when starting 
checksum calculation. 


IGNERR - ignore CRC/ECC error. Forces ECCERR bit in 
the SEQCTL register to zero, and causes the read error 
logic to ignore this error by continuing with its operation. 
The status bit EERR/CERR in the ECCS register is not af- 
fected by this control bit and will be set on error. 


DISPTY: disable parity checking. Setting this bit to one for- 
ces the PTYERR bit in the SEQCTL register to zero. Even 
if the FAIL bit in the current CS instruction is set, the se- 

quencer will continue its operation normally on parity error. 


TABLE 6-20. ECCCTL - ERROR CORRECTION REGISTER (0E) 
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6.4.9 SECCNT - Sector Count Register (OF) 


The sector count register is used to specify the 
number of iterations to perform the operation 
programmed into the control store. Writing any 
non-zero value to the SECCNT register causes 
the sequencer to start, so therefore the range of 
possible sector counts is from 1 to 255. Writing a 
zero to SECCNT during the data field will cause 
the sequencer to halt at the end of the current 
sector. The sector count is automatically decre- 
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mented at the start of the data field, after the byte 
sync or address mark character(s) have been 
detected (leading edge of BUFF or NOXFER). 
The SECCNT register can be written to at any 
time except the start of the data field. 


This register is cleared to zero by reset, or when 
the KILL bit in the SEQCTL register is set. It is 
NOT cleared by a halt on error, so that the sector 
in error can be determined. 


REGISTER | BIT | DIR | DEFINITION 
Por 20 | RW | Sector count va 


TABLE 6-21. SECCNT - SECTOR COUNT REGISTER (0F) 
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6.4.10 ECCP- ECC Parameter Register (10) 


REGISTER 


BT | DIR 
ae 








DEFINITION 


SYNCECC - include sync byte in the ECC calculation. This 
bit is initialized to one upon reset. If this control bit is set to 
one, the ECC calculation begins with the first data sync 
byte. Otherwise, the first data sync byte is excluded from 
the ECC calculation. 


WSYNCCERC - include sync byte in the CRC calculation. 
This bit is initialized to one upon reset. If this control bit is 
set to one, the CRC calculation begins with the first ID sync 
byte. Otherwise, the first data sync byte is excluded from 
the CRC calculation. 

DEG6/5 - RS ECC degree control bit. This bit is initialized 


to zero upon reset. If this bit is set to zero, degree 5 polyno- 
mial is selected, otherwise degree 6 will be used. 


WIFS5/3 - Interleave select. This bit is initialized to zero 
upon reset. Setting this bit to one will select five way inter- 
leave format, otherwise three way format will be used. 










TABLE 6-22. ECCP - ECC PARAMETER REGISTER (10) 
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6.4.11 ECCS - RS-ECC Status Register (11) 


DEFINITION 


EERR - ECC error detected. This bit is set whenever an 
ECC error is detected in any one of the interleaves. At least 
one of the status bits I4E - OE will also be set. This bit is 
cleared to zero after reset and before another operation is 
started. This bit is not affected by the control bit IGNERR, 
which prevent the status ECCERR from being set. 


CERR - CRC error detected. This status bit is set whenever 
a CRC error is detected in the ID field. This bit is cleared 
upon reset. The control bit |GNERR does not affect this 
status bit. 


I4E - ECC error in interleave 4. This bit is set only when an 
ECC error is detected in the interleave 4. The microproces- 
sor can read the syndrome bytes from this interleave only 
when this status bit is set. This status bit is cleared upon 
reset. It also be cleared by writing a zero into this bit. 


ISE - ECC error in interleave 3. This bit is set only when an 
ECC error is detected in the interleave 3. The microproces- 
sor can read the syndrome bytes from this interleave only 
when this status bit is set. This status bit is cleared upon 
reset. It also be cleared by writing a zero into this bit. 


I2E - ECC error in interleave 2. This bit is set only when an 
ECC error is detected in the interleave 2. The microproces- 
sor can read the syndrome bytes from this interleave only 
when this status bit is set. This status bit is cleared upon 
reset. It also be cleared by writing a zero into this bit. 


I1E - ECC error in interleave 1. This bit is set only when an 
ECC error is detected in the interleave 1. The microproces- 
sor can read the syndrome bytes from this interleave only 
when this status bit is set. This status bit is cleared upon 
reset. It also be cleared by writing a zero into this bit. 


lOE - ECC error in interleave 0. This bit is set only when an 
ECC error is detected in the interleave 0. The microproces- 
sor can read the syndrome bytes from this interleave only 
when this status bit is set. This status bit is cleared upon 
reset. It also be cleared by writing a zero into this bit. 


TABLE 6-23. ECCS - RS-ECC STATUS REGISTER (11) 
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6.4.12 SPORT - Syndrome Port (12) 


The microprocessor reads the syndrome bytes for 
each interleave through this port. The WD10C01 
automatically transfers the syndromes of the next 
interleave in error after all the syndromes in the 
current interleave are read. The microprocessor 
must read (interleave number * ECC degree) 
times from this port to complete a syndrome 
transfer from an interleave. The syndrome bytes 
are transferred starting with the highest byte from 
the lowest interleave number. Only the 
syndromes from an interleave in error are trans- 
ferred. If the microprocessor clears the error flag 
from an interleave, the syndromes from that inter- 
leave cannot be read, but the content of the 
syndrome registers are not destroyed. Those can 
be read by reseting the error flag to one. 


The syndrome bytes are valid only when sequen- 


cer is stopped. The syndrome registers are 
cleared upon reset. 


REGISTER BIT 


DIR | DEFINITION 
(120 | 70 | R___|_ SYNDR7-0 - Syndrome bit7-bito. 


WD10C01 


6.4.13 TEST - Test Register (16) 


This register is intended for test purpose in the 
manufacturing and must not be used in normal 
operations. It is described here only for reference. 


There are three test functions implemented in this 
register. First, writing into this register with any 
data, will set the OSC and CPUCLK outputs in a 
predetermined state. During the write cycle, the 
OSC output is set to 0 level and the CPUCLK 
output is set to a 1 level. 


Second, the microprocessor can write 080H into 
this register to disable the output signal WG. This 
signal will remain inactive until the microprocessor 
writes a OOH into the register. 


Third, the microprocessor can write OCOH into the 
register to increment the ID registers. Sub- 
sequently, the microprocessor must write OOH, 
before it can continue to increment the registers 
again. The output WG is also disabled during the 
test operation. 


TABLE 6-24. SPORT - SYNDROME PORT (12) 
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6.4.14 SKIP - Skip Address Register (17) 


This register is not affected by reset. The SKIP 
register is used to perform an absolute jump to 
the location specified at the completion of a con- 
trol store instruction that has the SKPEN bit set to 
one. This can typically be used to define whether 
the current operation is to be a sector read or a 
sector update write. Consider the following 
generalized control store program that has three 
parts: ID search, read data field, and write data 
field. 
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When the SKIP register is set to address 05, the 
WD10C01 will perform a sector read operation. 
When the SKIP register is set to address OC, the 
WD10C01 will perform a sector write operation. A 
more detailed example can be found in a sub- 
sequent section of this document. 


REGISTER | BIT | DIR | DEFINITION 
SKIP4-0 


TABLE 6-25. SKIP - SKIP ADDRESS REGISTER (17) 





ADDRESS | CONTROL STORE 
OPERATION 
ID SEARCH 
ID SEARCH 


ID SEARCH 
0 
0 
0 
0 
0 
0 






















05 | READDATAFIELD 
06 || READDATAFIELD 
07 | READDATAFIELD 
08 | -READDATAFIELD 
09 | READDATAFIELD 
0A | READDATAFIELD 
0B | STOP 
0G | WRITEDATAFIELD 
0D | WRITEDATAFIELD 
OE | WRITEDATAFIELD 
OF | WRITEDATAFIELD 
10 | WRITEDATAFIELD 
11 | WRITEDATAFIELD 
ae ec a 


TABLE 6-26. SKIP CONTROL STORE 
EXAMPLE 


1 
2 
3 
4 
5 
7 
A 
C 
E 
F 
10 
11 
12 
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6.5 ID REGISTER GROUP 


The eight ID registers (IDO - ID7) are used to set 
the ID field during format and read/write opera- 
tions. Writing to the ID registers sets the field to 
search for, or to write during format. These 
registers are refered to as the ID write registers. 
The first four ID write registers are set up as a 
32-bit counter, and they automatically increment 


REGISTER 


WD10C01 


at the start of the data field. The second four are 
simple registers and are intended for use as flag 
and defect indicators. 


The ID read registers contain the last ID field read 
from the media (valid when IDFULL in SISR is 
true). These registers must be read when the se- 
quencer is NOT reading an ID field, or else the 
CPU will not read the correct value. 


BIT | DIR | DEFINITION 


18 IDO bits 7-0 (counter MSbyte) 


TABLE 6-27. IDO - ID REGISTER 0 (18) 


REGISTER | BIT | DIR 
19 


REGISTER BIT 
7-0 R/W 


DEFINITION 
ID1 bits 7-0 (counter) 


TABLE 6-28. ID1 - ID REGISTER 1 (19) 


| DIR | DEFINITION 


ID2 bits 7-0 (counter) 


TABLE 6-29. ID2 - ID REGISTER 2 (1A) 


REGISTER BIT 


| 


DIR | DEFINITION 


ID3 bits 7-0 (counter LSbyte) 


TABLE 6-30. ID3 - ID REGISTER 3 (1B) 
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REGISTER | BIT | DIR | DEFINITION 
ID4 bits 7-0 (flag) 


TABLE 6-31. ID4 - ID REGISTER 4 (1C) 


REGISTER | Bit | DIR | DEFINITION 


IDS bits 7-0 (fag) 


TABLE 6-32. ID5 - ID REGISTER 5 (1D) 


REGISTER pit | DIR | DEFINITION 
1E ID6 bits 7-0 (flag) 


TABLE 6-33. ID6 - ID REGISTER 6 (1) 


REGISTER | BIT | DIR | DEFINITION 


1E 


TABLE 6-34. ID7 - ID REGISTER 7 (1F) 


ID7 bits 7-0 (flag) 
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6.6 


6.6.1 


6.6.2 


DEVICE PROGRAMMING 


Initialization 


. Write one and then zero to the SRST bit of 


the SRESET register to complete the 
device reset sequence. 


. Write the remainder of the bits of the 


SRESET register to the CPU and OSC 
clock speeds, and ID counter size and 
data request timing. 


. Clear all interrupts that can be cleared by 


writing OFFH to the SISR (some may still 
be set because they are level true). Write 
the initial mask to the SIMR. 


. Configure port Y. 


. Configure the address mark control bits 


using the AMC register. 


. Set up the ECC by programming the EC- 


CCTL and ECCP registers. Set CRCNIT in 
the ECCCTL register to the appropriate 
value for a zero seed or a one’s seed. 


. Load the control store program into the 


control store. 


Command Programming 


. Load the control store with the particular 


instructions appropriate for the command 
desired (format, read, write, etc.), if neces- 
sary. 


. Set the START, LOOP, and SKIP registers 


to the appropriate values for the control 
store program. 


. Write the number of sectors to do to SEC- 


CNI. This also starts the command se- 
quencer. 


. Clear the interrupt status bits, and set the 


mask. 


. Wait for SEQSTP. Check the SEQCTL and 


ECCS status bits for an error. 


6.6.3 Control Store Programming 


There are a few ’tricks’ in programming the 
WD10C01 control store that are not indicated by 
the discussions of the individual control bits: 


READ BYTE SYNC 


On formats that use a simple byte sync byte (like 
ESDI) for ID and data field markers, the search is 
performed by setting the control byte bits RG and 
CMPEN, and the count field is set with a maxi- 
mum byte timeout count. The condition of no byte 
sync yet found, and RG * CMPEN set, defines 
this mode. AMDET is not used and has no effect 
on this operation. Checksum calculation starts 
when the sync byte is detected, and the sync byte 
is included in the calculation. 


WRITE BYTE SYNC 


Write byte sync is used to mark the start of the 
byte string for which the ECC/CRC checksum is 
calculated. To do this, set WG and CMPEN in the 
control byte. The start of the contro! store instruc- 
tion with WG and CMPEN set clears the check- 
sum register to the state defined by CRCNIT. The 
transition to the next instruction begins the check- 
sum calculation. For example, in a ST412 drive 
the ID field might be defined by the byte string: A1 
FE ID ID ID FLAG ECC ECC ECC ECC; with PLL 
sync before, and gap after. The contro! store in- 
structions would be coded as follows. 
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ADDRESS DATA COUNT CONTROL ERROR 





ee 
At 
FE 
CHK 
eo 


02 
03 
03 


Feo foo 
ID |W svseL__|_ ID field 


oo WG pad and splice 
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WG,CMPEN PLL sync field 
WG,AM 


WG,SVSEL flag byte 
WG,SVSEL 


TABLE 6-35. WRITE BYTE SYNC EXAMPLE 


In the example, control store instruction 00 con- 
tains the WG-CMPEN combination that says to 
begin checksum calculation on instruction 01; 
therefore, the bytes defined in instructions 01 
through 05 are included in the checksum calcula- 
tion. The calculation is terminated by the CHK 
value code in instruction 05. 


DATA FIELD SIZES 


The data field size is set by using multiple control 
store instructions to build up the size in 256 (or 
less) increments. Two issues come up with this 
method: 


1) The last data field instruction must be 
marked to ensure correct buffer data 
transfer timing and checksum calculation. 
The LAST bit is used with the BUFF or 
NOXFER bit to perform this marking. 


2) For programming purposes, it is desirable 
to not have to change the control store 
significantly when changing sector size. To 
do this, allocate enough control store in- 
structions to be able to set the largest sec- 
tor size to be supported. Then, adjust the 
count fields in all of the instructions to get 
the desired sector size. For example, if a 
controller supports 256, 512, and 1024 
byte sectors, use the programming shown 
in the example below: 


Rel Addr 






256 | 812 | 1024 
poo | oF FR 


TABLE 6-36. DATA FIELD SIZE EXAMPLE 





If the LAST bit is being used as an interrupt, the 
last instruction can be split into two parts. The 
second part contains the LAST bit, and can be 
adjusted to the required time before the end of the 
sector, since the leading edge of LAST generates 
the interrupt. 


ID SEARCH AND FLAG BYTES 


When specifying an ID field, it is desirable to have 
address bytes that are compared on a search, 
and flag bytes that are not. To do this, split the ID 
field in the control store into two separate instruc- 
tions for address and flag. When performing an ID 
search, set the CMPEN bit only in the ID address 
instruction, and not in the ID flag instruction. 


DATA CHECKSUM VERIFY 
To do a data field ECC or CRC verify only com- 


mand, set the data field source as NOXFER. No 
data will be transferred to the buffer. 
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DATA COMPARE VERIFY 


To do a data field compare verify, set the RCMP 
bit in the SEQCTL register, and set the CMPEN 
bit in the data field control store instruction. Data 
will be transferred from the data buffer and com- 
pared with the incoming disk data. 


FILL GAP TO END OF TRACK 


To generate fill data through to the end of the 
track during format, set the WIX bit in the last 
control store instruction, and set WG and the fill 
character. The WD10C01 will fill in gap bytes until 
index occurs. This also works for gaps to sector 
marks. 


WD10C01 


6.6.4 Programming Examples 


This section gives programming examples for 
$1412 format, read, and write commands. The 
following design parameters are assumed: 


1. The ID field is three bytes of address, one 
byte of flag, and two bytes of CRC. 


2. Intersector gaps are 20 bytes of 04EH 
data, PLL sync fields are 12 bytes of 
OOOH. 


3. ID address mark and marker byte are 
OA1FEH, data address mark and marker 
byte are OA1F8H. 


4. Data field is protected through degree six 
ECC with interleave factor of five. There 
are 30 bytes of checksum. 


The WD10C01 registers are programmed as fol- 
lows: 


SRESET: ID3$4 = 1 (3 bytes of address counter) 
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6.6.4.1 Format Track Example 


ADDRESS VALUE 


= 


=r “NJ oO alk 
yO PhO a oO 


X 


aS 
m 


- @) w iw m1 |> 1 | > 
Tr cic ee) m 
= 1/7 

m1) 


02 


oO 
\o) 
Ss 


— =alolo ° S =) 210 ron) 
nN o(n O > or |B | = 
2 


O 


HK 


N 
Oo 
= 


—_k, 


BUFF 


NIN 
mim) 


7F 


m 


BUFF, LAST 


iT 
© 


WIX 
STOP 


oS 
—s 





COUNT 


START = 00, LOOP = 01, SKIP = NOT USED 













CONTROL NOTES 

CWSEL 
WG 

WG 

WG 





WG | post index gap 
WG | address mark 
WG | write splice 
address mark 
WG, JMPEN,DAC 


CWSEL stop at end of 
track 


TABLE 6-37. FORMAT TRACK EXAMPLE CONTROL STORE 


Line by line discussion of Format Track Example: 


00: This instruction just waits until the leading 
edge of index. No writing is occurring. If there is 
no index signal working on the drive, the CPU will 
have to timeout and issue an abort. The DAC bit 
is zero to select the checksum for the ID, as 
specified by the SRESET register. 


01: This instruction is the standard 4E gap from 
index to the start of the first sector. This instruc- 
tion is also the intersector gap, because after the 
data field write splice on instruction 11 is written, 
the WD10C01 will jump to this address specified 
by the LOOP register. 


02: This instruction is the PLL sync field for the ID 
field. The WG - CMPEN combination also marks 


the start of the CRC calculation starting with in- 
struction 03. 


03: This is the first address mark byte for the ID 
field. The AM bit generates AMENA with the AMC 
register, suppressing the clock bit in the A1 byte. 


04: This is the second address mark byte, and is 
treated as simple immediate data for format pur- 
poses. 


05: This is the ID address and flag field. 
06: ID CRC field. The count field is set to (2-1) 


bytes for the ID CRC. The end of this instruction 
also stops the checksum calculation. 
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07: ID write splice and data PLL sync field. This 
gap protects the end of the ID field from the start 
of the data field on later update write commands. 


08: Data PLL sync field. The WG - CMPEN com- 
bination also marks the start of the ECC calcula- 
tion starting with instruction OA. The DAC bit is set 
here to select the data field checksum, and in this 
case it also Causes a one byte prefetch from the 
buffer. 


09: This is the first address mark byte for the data 
field. The AM bit generates AMENA with the AMC 
register, suppressing the clock bit in the A1 byte. 


OA: This is the second address mark byte, and is 
treated as simple immediate data for format pur- 
poses. 


OB-OD: These are the first three instructions that 
define the sector data field. The data field is split 
into four control instructions so that switching be- 
tween sector sizes will not require reordering the 
control store data (see above). The example 
shows a 512 byte sector. 


OE: The last instruction of the data field marks the 
end of the data field using the LAST bit set with 
BUFF. 


OF: Data ECC field. ECC degree six with inter- 
leave factor of five is used, the count field is set to 
(30-1) bytes. The end of this instruction also stops 
the checksum calculation. 


10: Data field write splice. This instruction pads 
the end of the data field, making sure that the 
checksum is not lost by the drive. The JMPEN bit 
is also set in this instruction, meaning that the 
next instruction to be accessed will be the one 


addressed by the LOOP register, in this case 01. 
This happens only if SECCNT is not zero. If SEC- 
CNT is zero, the next control instruction is 11. 


11: After the last sector, SECCNT is zero. After 
instruction 10 is done, the next instruction will be 
this one instead of instruction 01 (LOOP register). 
This instruction writes the 4E gap until index. 


12: The STOP bit causes the sequencer to shut 
down immediately and turn off all external signals 
(like WG, etc.). 


The CPU performs the FORMAT TRACK com- 
mand as follows: 


1. After setting up the control store and ad- 
dress registers as defined above, write the 
total sectors per track to the SECCNT 
register. 


2. Write DXFER, FAULT, and SEQSTP true 
to the SISR register to clear those status 
bits, and to the SIMR register to enable 
them. 


3. Wait until GINT is true with a timeout in 
case INDEX is not present on the inter- 
face. Check FAULT for error, and abort if 
true. If DXFER goes true, update the ID 
write registers with the next ID field (when 
using non-consecutive, i.e., not 1:1 inter- 
leave). 


4. Repeat step 3 for all sectors on the track. 


5. After the last sector, wait for SEQSTP to be 
true, indicating the end of the command. 
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6.6.4.2 Read Sector Example 






a La 
ee 


pos 


08 BUFF 3 


0B | BUFF, LAST 


START = 00, LOOP = 00, SKIP = NOT USED 


ADDRESS VALUE COUNT CONTROL NOTES 


Al WIAM RG,CWSEL, RTY| address mark 
search 


oO 
oO 
i ECC 
iE AR Fal acl 

FAIL 
i Dk 
read 
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RG,CWSEL, RTY| ID marker byte 


RG, SVSEL ID address 
CMPEN 


RG, SVSEL ID flag 
RG, SVSEL 
allow ID retry 


RG, CWSEL, address mark 
DAC, FAIL search 


RG, CWSEL, 
DAC, FAIL 


_RG,SVSELDAC | ECO 





















data marker byte 


TABLE 6-38. READ SECTOR EXAMPLE CONTROL STORE 


Line by line discussion of Read Sector example: 


00: This is the first instruction of the read sector 
command. The WIAM bit tells the WD10C01 to 
search for an ID address mark byte. The 
WD10C01 will not timeout, so the CPU will have 
to abort after some period of time, if necessary. 
The DAC bit is zero during the ID field to select 
the ID checksum. The RTY bit is set so that if a 
read error (in this case, no sync match after 
AMDET true) occurs, a retry will be performed. 


01: This tells the WD10C01 to verify the ID 
marker byte. If it does not compare exactly, an ID 
retry occurs (see below) because the RTY bit is 
set. 


02: This is the ID address field. The CMPEN bit 
causes a compare of the ID write registers with 
the incoming ID field. The incoming ID is also 
written to the ID read registers. 


03: This is the ID flag field. This control store 
instruction is separate from the ID address field 
because the flag byte is not compared with the ID 
write register. It is still written to the ID read 
register. 


04: ID CRC field. The count field is set to (2-1) 
bytes for the ID CRC. This instruction switches 
the checksum shift register into check mode. 


05: This instruction is both a pad over the write 
splice and a check for an ID retry. The ID com- 
pare status and checksum error status are latched 





21-40 


11/19/91 Sf, 


PROGRAMMING REFERENCE 


WD10C01 





and held, and the RTY bit is now set, allowing the 
checking of this status. An ID retry occurs if the ID 
did not match, or if there was a checksum error. 
The checksum error is latched into the IDERR bit 
for future reference. We waited until this instruc- 
tion to check for an error so that the ID read 
registers could be loaded with this ID field. 


06: The WDAM bit tells the WD10C01 to look for 
the data address mark. The (1F) indicates the 
byte count that is loaded into the byte count. This 
value is the maximum number of byte times that 
the WD10C01 will look for the address mark. This 
prevents locking up on a subsequent data field 
address mark. An error here causes an immediate 
halt, with SYNCER set in the SEQCTL register, 
because the FAIL bit is set. 


07: This is the data marker byte. The CMPEN bit 
indicates that the byte must compare exactly with 
the immediate data byte. An error here causes an 
immediate halt, with SYNCER set in the SEQCTL 
register, because the FAIL bit is set. 


08-0A: These are the first three instructions that 
define the sector data field. The data field is split 
into four control instructions so that switching be- 
tween sector sizes will not require rearranging the 
control store data (see above). The example 
shows a 256 byte sector. On ECC verify com- 
mands, change BUFF to NOXFER. On compare 
verify commands, set BUFF, the CMPEN bit in the 
control byte, and RCMP in the SEQCTL register. 


OB: The last instruction of the data field marks the 
end of the data field using the LAST bit set with 
BUFF. LAST must be used for BUFF or NOXFER. 


OC: Data ECC field. ECC degree six with inter- 
leave factor of five is used, the count field is set to 
(30-1) bytes. This instruction switches the check- 
sum shift register into check mode. 


OD: The purpose of this instruction is to turn off 
RG, resetting any external data decoder circuits. 
The JMPEN bit is also set in this instruction, 
meaning that the next instruction to be accessed 
will be the one addressed by the LOOP register, 
in this case 00. This happens only if the SECCNT 
register is not zero. If SECCNT is zero, the next 
instruction is 12. The FAIL bit is also set, causing 
the checksum status to be checked, and if there 
was an error, the command stops, with ECCERR 
set in the SEQCTL register. 


OE: After the last sector, the SECCNT register is 
zero. After instruction OD is done, the next instruc- 
tion will be this one instead of instruction 00 
(LOOP register). This instruction stops the com- 
mand immediately. 


The CPU performs the READ SECTOR command 
as follows: 


1. After setting up the control store and ad- 
dress registers as defined above, write the 
sector count to the SECCNT register to 
start the transfer. 


2. Write FAULT, IDFULL, and SEQSTP true 
to the SISR register to clear those status 
bits, and to the SIMR register to enable 
them. 


3. Wait until GINT is true with a timeout in 
case INDEX is not present on the inter- 
face. Check FAULT for error, and abort if 
true. If IDFULL is true, perform any checks 
on the value in the ID FIFO. If SEQSTP is 
true, make sure that no error occurred that 
must be serviced. Clear the status ser- 
viced. 
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6.6.4.3 Write Sector Example 


ADDRESS VALUE 


> 


m — 


‘@) 
- 
A 


WIAM 





© 
—_ 





© 
Nh 


oO 
oO 


O ;O Oo 


Oo 
TT 


NO 


= 1/7 


o) 
N 
> 


© 
© 
Tl 
(oe) 


BUFF 

BUFF 

BUFF 

BUFF, LAST 
CHK 


fo) 
> 

= 

a 


FF 


ro) 
© 


o) 
© 
NO 


STOP 


COUNT 


START = 00, LOOP = 00, SKIP = NOT USED 


PROGRAMMING REFERENCE 







CONTROL NOTES 


RG,CWSEL, RTY| address mark 


search 


RG,CMPEN, RTY) ID marker byte 


RG, SVSEL ID address 
CMPEN . 


RG, SVSEL ID flag 
RG, SVSEL 
RTY 


WG, CMPEN, PLL sync 


DAC 


CW SEL stop at end of 
cmd 






TABLE 6-39. WRITE SECTOR EXAMPLE CONTROL STORE 


Line by line discussion: 


00: This is the first instruction of the write sector 
command. The WIAM bit tells the WD10C01 to 
search for an ID address mark byte. The 
WD10C01 will not timeout, so the CPU will have 
to abort after it times out, if necessary. The DAC 
bit is zero during the ID field to select the ID 
checksum. The RTY bit is set so that if a read 
error (in this case, no sync match after AMDET 
true) occurs, a retry will be performed. 


01: This tells the WD10C01 to verify the ID 
marker byte. If it does not compare exactly, an ID 
retry occurs (see below) because the RTY bit is 
set. 


02: This is the ID address field. The CMPEN bit 
causes a compare of the ID write registers with 


the incoming ID field. The incoming ID is also 
written to the ID read registers. 


03: This is the ID flag field. This instruction is 
separate from the ID address field because the 
flag byte is not compared with the ID write 
register. It is still written to the ID read register. 


04: ID CRC field. The count field is set to (2-1) 
bytes for the ID CRC. This instruction switches 
the checksum shift register into check mode. 


05: This instruction spaces over the ID field write 
splice to the start of the data field, protecting the 
ID checksum in the process. This instruction also 
performs a check for an ID retry. The ID compare 
status and checksum error status are latched and 
held, and the RTY bit is now set, allowing the 
checking of this status. An ID retry occurs if the ID 
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did not match, or if there was a checksum error. 
The checksum error is latched into the IDERR bit 
for future reference. 


06: Data PLL sync field. This instruction is the 
start of the update write sector data. The WG - 
CMPEN combination also marks the start of the 
ECC calculation starting with instruction 07. 


07: This is the first address mark byte for the data 
field. The AM bit generates AMENA with the AMC 
register, suppressing the clock bit in the A1 byte. 


08: This is the data marker byte, and is treated as 
simple immediate data for write sector purposes. 


09-0A: These are the first three instructions that 
define the sector data field. The data field is split 
into four control instructions so that switching be- 
tween sector sizes will not require reordering the 
control store data (see above). The example 
shows a 1024 byte sector. 


OB: The last instruction of the data field marks the 
end of the data field using the LAST bit set with 
BUFF. 


OC: Data ECC field. ECC degree six with inter- 
leave factor of five is used, the count field is set to 
(30-1) bytes. The end of this instruction also stops 
the checksum calculation. 


OD: Data field write splice. This instruction pads 
the end of the data field, making sure that the 
checksum is not lost by the drive. The JMPEN bit 


WD10C01 


is also set in this instruction, meaning that the 
next instruction to be accessed will be the one 
addressed by the LOOP register, in this case 00. 
This happens only if the SECCNT register is not 
zero. If SECCNT is zero, the next control instruc- 
tion is OE. 


OE: After the last sector, SECCNT is zero. After 
instruction 11 is done, the next instruction will be 
this one instead of instruction 00 (LOOP register). 
This instruction stops the command immediately. 


The CPU performs the WRITE SECTOR com- 
mand as follows: 


1. After setting up the control store and ad- 
dress registers as defined above, write the 
sector count to the SECCNT register to 
Start the transfer. 


2. Write IDFULL, FAULT, and SEQSTP true 
to the SISR register to clear those status 
bits, and to the SIMR register to enable 
them. 


3. Wait until GINT is true with a timeout in 
case INDEX is not present on the inter- 
face. Check FAULT for error, and abort if 
true. If IDFULL is true, perform any checks 
on the data in the ID FIFO. If SEQSTP is 
true, check to see if an error occurred that 
must be serviced. Clear the status ser- 
viced. 
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6.6.4.4 Read and Write Sector Example the contents of the SKIP register. The control 
This example makes use.of the SKIP register to Store example shown in the table below is divided 


merge the read and write sector operations into into the 1D search, read data field, and write data 
one control store program. Selection between field sections. 
read and write is performed solely by changing 


ADDRESS |. VALUE 


Al 
FE 


ta 


CONTROL 
RG,CWSEL, RTY 
RG,CMPEN, RTY 
RG, SVSEL, CMPEN 












COUNT 
WIAM 







O 
NO 


i 
—s 






OZ ca! 

03 | DL SRG, SVSEL 
RG, SVSEL 
05 | 00 | |, SKPEN, RTY 
of oo | waaitpast splice 
09 | A1_|_WDAM(F) | RG,CWSEL,DAC,FAIL _|_ address marker search 
0A | FB |__| «RG, SVSEL,DAC | datamarkerbyte 
0B | BUFF | 3F___| RG, SVSELDAC | datafiold 
RG, SVSELDAC 
0D | BUFF___| 3F_|_ RG, SVSEL,DAC 

LAST 
re D 


0 1 
JMPEN,DAC, FAIL 
CW SEL 
WG, AM,DAC address mark 

WG, DAC 
WG, SVSEL,DAC 
WG, SVSEL,DAC 
WG, SVSEL,DAC 


WG, SVSEL,DAC data field 


0 

1 

F8 
WG, SVSEL,DAC 
WG,JMPEN,DAC write splice 


00 sd STOP CW SEL stop at end of cmd 
START = 00, LOOP = 00, SKIP = 08 for read, 14 for write 


TABLE 6-40. READ AND WRITE SECTOR EXAMPLE CONTROL STORE 


STOP 









0 
A 
BUFF 


BUFF 


BUFF 


BUFF 
LAST 


t 






— 
N 


RG, SVSEL,DAC 


10 
11 

14 
15 
16 
18 
19 
1A 


02 
0B 
00 
FF 
FF 
FF 
FF 
1D 
02 
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Line by line discussion of Read and Write ex- 
ample: 


00: This is the first instruction of the ID search. 
The WIAM bit tells the WD10C01 to search for an 
ID address mark byte. The WD10C01 will not 
timeout, so the CPU will have to abort after it 
times out, if necessary. The DAC bit is zero during 
the ID field to select the ID checksum. The RTY 
bit is set so that if a read error (in this case, no 
sync match after AMDET true) occurs, a retry will 
be performed. 


01: This tells the WD10C01 to verify the ID 
marker byte. If it does not compare exactly, an ID 
retry occurs (see below) because the RTY bit is 
set. 


02: This is the ID address field. The CMPEN bit 
causes a compare of the ID write registers with 
the incoming ID field. The incoming ID is also 
written to the ID read registers. 


03: This is the ID flag field. This instruction is 
separate from the ID address field because the 
flag byte is not compared with the ID write 
register. It is still written to the ID read register. 


04: ID CRC field. The count field is set to (2-1) 
bytes for the ID CRC. This instruction switches 
the checksum shift register into check mode. 


05: This instruction performs a check for an ID 
retry. The ID compare status and checksum error 
status are latched and held, and the RTY bit is 
now set, allowing the checking of this status. An 
ID retry occurs if the ID did not match, or if there 
was a checksum error. The checksum error is 
latched into the IDERR bit for future reference. 
Also, the SKPEN bit is set, meaning the next ad- 
dress (assuming no errors occurred) will be the 
value in the SKIP register, which is 08 for read 
sector, and 14 for write sector. 


READ DATA FIELD 


08: This instruction spaces over the |D field write 
splice to the start of the data field, protecting the 
ID checksum in the process. 


09: The WDAM bit tells the WD10C01 to look for 
the data address mark. The (1F) indicates the 
byte count that is loaded into the byte count. This 
value is the maximum number of byte times that 
the WD10C01 will look for the address mark. This 
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prevents locking up on a subsequent data field 
address mark. An error here causes an immediate 
halt, with SYNCER set in the SEQCTL register, 
because the FAIL bit is set. 


OA: This is the data marker byte. The CMPEN bit 
indicates that the byte must compare exactly with 
the immediate data byte. An error here causes an 
immediate halt, with SYNCER set in the SEQCTL 
register, because the FAIL bit is set. 


0B-0D: These are the first three instructions that 
define the sector data field. The data field is split 
into four instructions so that switching between 
sector sizes will not require reordering the control 
store data (see above). The example shows a 256 
byte sector. On ECC verify commands, change 
BUFF to NOXFER. On compare verify com- 
mands, set BUFF, the CMPEN bit in the control 
byte, and RCMP in the SEQCTL register. 


OE: The last instruction of the data field marks the 
end of the data field using the LAST bit set with 
BUFF. LAST must be used for BUFF or NOXFER. 


OF: Data ECC field. ECC degree six with inter- 
leave factor of five is used, the count field is set to 
(30-1) bytes. This instruction switches the check- 
sum shift register into check mode. 


10: The purpose of this instruction is to turn off 
RG, resetting any external data decoder circuits. 
The JMPEN bit is also set in this instruction, 
meaning that the next instruction to be accessed 
will be the one addressed by the LOOP register, 
in this case 00. This happens only if the SECCNT 
register is not zero. If SECCNT is zero, the next 
control instruction is 11. The FAIL bit is also set, 
causing the checksum status to be checked, and 
if there was an error, the command stops, with 
ECCERR set in the SEQCTL register. 


11: After the last sector, the SECCNT register is 
zero. After instruction 10 is done, the next instruc- 
tion will be this one instead of instruction 00 
(LOOP register). This instruction stops the com- 
mand immediately. 


WRITE DATA FIELD 


14: Data PLL sync field. This instruction is the 
start of the update write sector data. The WG - 
CMPEN combination also marks the start of the 
ECC calculation starting with instruction 15. 
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15: This is the first address mark byte for the data 
field. The AM bit generates AMENA with the AMC 
register, suppressing the clock bit in the A1 byte. 


16: This is the data marker byte, and is treated as 
simple immediate data for write sector purposes. 


17-19: These are the first three instructions that 
define the sector data field. The data field is split 
into four instructions so that switching between 
sector sizes will not require reordering the control 
store data (see above). The example shows a 
1024 byte sector. 


1A: The last instruction of the data field marks the 
end of the data field using the LAST bit set with 
BUFF. 


1B: Data ECC field. ECC degree six with inter- 
leave factor of five is used, the count field is set to 
(30-1) bytes. The end of this instruction also stops 
the checksum calculation. 


1C: Data field write splice. This instruction pads 
the end of the data field, making sure that the 
checksum is not lost by the drive. The JMPEN bit 
is also set in this instruction, meaning that the 
next instruction to be accessed will be the one 
addressed by the LOOP register, in this case 00. 
This happens only if the SECCNT register is not 
zero. If SECCNT is zero, the next control instruc- 
tion is 1D. 


1D: After the last sector, SECCNT is zero. After 
instruction 1C is done, the next instruction will be 
this one instead of instruction 00 (LOOP register). 
This instruction stops the command immediately. 


The CPU performs the READ SECTOR command 
as follows: 


1. After setting up the control store and ad- 
dress registers as defined above, write 06 
to the SKIP register, and then write the 
sector count to the SECCNT register to 
start the transfer. 


2. Write IDFULL, FAULT, and SEQSTP true 
to the SISR register to clear those status 
bits, and to the SIMR register to enable 
them. 


3. Wait until GINT is true with a timeout in 
case INDEX is not present on the inter- 
face. Check FAULT for error, and abort if 
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true. If IDFULL is true, perform any checks 
on the data in the ID FIFO. If SEQSTP is 
true, check to see if an error occurred that 
must be serviced. Clear the status ser- 
viced. 


The CPU performs the WRITE SECTOR com- 
mand as follows: 


1. After setting up the control store and ad- 
dress registers as defined above, write OF 
to the SKIP register, and then write the 
sector count to the SECCNT register to 
Start the transfer. 


2. Write IDFULL, FAULT, and SEQSTP true 
to the SISR register to clear those status 
bits, and to the SIMR register to enable 
them. 


3. Wait until GINT is true with a timeout in 
case INDEX is not present on the inter- 
face. Check FAULT for error, and abort if 
true. If IDFULL is true, perform any checks 
on the data in the ID FIFO. If SEQSTP is 
true, check to see if an error occurred that 
must be serviced. Clear the status ser- 
viced. 


6.6.5 ID Retry and Error Conditions 


The WD10C01 manages errors by using the RTY 
and FAIL bits in the control store error control 
byte. These bits tell the WD10C01 when to check 
its internal error status bits, and what to do about 
the error. All internal status bits in the WD10C01 
are held in their error state until reset by a retry, or 
by writing to the START register. 


If an error occurs when or before the RTY bit is 
set, an ID retry is performed. The LOOP register 
address will be loaded into the control store ad- 
dress register, restarting the sector. Also, the RG 
signal is switched false for one whole byte time to 
reset external decoders/PLLs. If the control store 
instruction at the LOOP address does not specify 
that RG is true, then it will stay false. 


If an error occurs when or before the FAIL bit is 
set, an immediate abort of the command occurs 
when FAIL goes true. The appropriate error status 
bit(s) are set, and the sequencer stops. 
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The following list summarizes the read error con- 
ditions of the WD10C01: 


1. When executing a WIAM or WDAM opera- 
tion, and the AMDET signal goes true, but 
the sync byte does not match within the 
sixteen bit timeout period. SYNCER will 
be set true if a halt is commanded (FAIL 
set). 


2. When searching for a simple byte sync 
byte, and the count in the control store 
count field is exhausted. SYNCER will be 
set true if a halt is commanded (FAIL set). 


3. Once byte sync is established, any read 
compare operations (CMPEN bit set) that 
fail. In the case of immediate data, this 
handles the ST412 second address mark 
byte (FE or F8) and the SYNCER bit will 
be true if a halt is commanded (FAIL set). 
In all other cases (i.e., buffer or ID data), 
the CMPERR bit is be true if a halt is com- 
manded (FAIL set). 


4. Any checksum error. This error status is 
retained by the IDERR bit in the SEQCTL 
register if a retry is commanded (RTY set) 
until the next ID field starts. The ECCERR 
bit is set if an abort was commanded (FAIL 
set). In this case, the checksum shift 
register contains the correction syndrome. 
The register ECCS shows the additional 
ECC status. 


5. When executing a WDAM operation, if the 
AMDET signal does not go true, and the 
count in the control store count field is ex- 
hausted. SYNCER will be set true if a halt 
is commanded (FAIL set). 


6.6.6 Error Recovery 


When a read error occurs that causes a halt of the 
command before it is completed, certain steps 
must be performed to recover from that error. 
When the sequencer stops, the following condi- 
tions are in effect: 


1. The SECCNT register contains a 
remainder. If the error is an ID error or a 
sync error (SYNCER set), this is the num- 
ber of sectors to read including the one in 
error. Any other error gives the number of 
sectors to read after the one in error. 


2. The ID set registers are set to an ID field. If 
the error is a sync error, this is the sector 
address of the one in error. Any other error 
gives the sector address following the one 
in error. In general, any error that is 
detected after the data field transfer starts 
(DXF went true, see the SEQSTS register) 
will cause SECCNT and the ID write 
registers to be set for the sector following 
the one in error. 


3. The SEQCTL read bits define the error. If 
ECCERR is set, then the error is a check- 
sum error. lf CMPERR is set, the errorisa 
verify or second address mark byte error. 
If SYNCER is set, the error is a byte sync 
error. 


4. The internal checksum register may con- 
tain a correction syndrome, depending on 
the type of error. 


The SECCNT contains a non-zero remainder. 
SECCNT is inhibited from restarting the sequen- 
cer by the latched error status. In order to restart 
for retry or continuing, the START register must 
be written with the starting control store address. 
This immediately clears any error status 
(SEQCTL read bits), and if the SECCNT register 
is still non-zero, will cause the sequencer to start. 
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6.6.7 Error Correction 


The Reed-Solomon ECC implemented in the 
WD10C01 can correct up to 2 error bytes (degree 
5) and up to 3 error bytes (degree 6) per inter- 
leave. Depending on the interleave factor being 
used, it can correct up to 30 bytes of error within a 
sector. 


During read operations, the device produces com- 
posite syndromes. These syndromes are used by 
the error correction routine (microprocessor) to 
calculate the error location and error value. The 
microprocessor responses to the SEQSTP inter- 
rupt by first reading the SISR and the ECCS 
registers to determine the type of failure. If the 
EERR bit in the ECCS is set, the microprocessor 
determines which interleaves are in error by read- 


ing the status bits IOE-I4E in the ECCS. The 
microprocessor then start reading the SPORT 
register to transfer the syndromes. The WD10C01 
automatically transfer the syndromes from the 
lowest interleave number. The highest byte is 
transferred first. The microprocessor has to read 
the SPORT register five times for degree 5 and 
six times for degree 6 to complete the syndrome 
transfer of an interleave. After all syndromes of 
the interleave are transferred, the microprocessor 
must reset the corresponding error status bit in 
the ECCS by writing a 0 into that bit. The 
microprocessor can then continue reading the 
syndromes of the next interleave. 
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7.0 DC ELECTRICAL SPECIFICATIONS 


7.1 MAXIMUM RATINGS 


0°C to 70°C 
Storage temperature | -65°C to 150°C 


Voltage on any pin -0.3 to Vpp+0.3 Volts 
with respect to Vss 


Voltage on Vpp with 7 Volts 
respect to Vss 


Leakage current +10 LA 


Power dissipation 1000 mW 

at X1=32 MHz, 
RRCLK=27 MHz, 
0°C, all outputs open 


Input Static 2000 V pin to pin 
Discharge Protection 


NOTE 

Stresses above those listed under Maximum 
Ratings may cause permanent damage to the 
device. This is a stress rating only and functional 
operation of the device at these or any other con- 
ditions above those indicated in the operational 
section of the specification is not implied. Ex- 
posure to absolute maximum rating conditions for 
extended periods may affect product reliability. 
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7.2. | STANDARD TEST CONDITIONS 


The characteristics below apply for the following 
standard test conditions, unless otherwise noted. 
All voltages are referenced to Vss (OV Ground). 
Positive current flows into the referenced pin. 


Operating temperature range 0° to 70° C 


Vpp supply voltage with +5 Volts + 
respect to Vss 0.5V 
0 Volts 


Latch-up current (min) 
Operating humidity range 20 to 95% 


X1 input operating frequency 32 MHz(max) 
with crystal 8 MHz (min) 
X1 input operating frequency 
with TTL source 













25 MHz(max) 
--- MHz (min) 
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7.3 DC CHARACTERISTICS 


SYMBOL |PARAMETER [MIN 
_Vin___| Input High Voltage | 2.0 
| Vu____| Input Low Voltage | -- 
tia | Input High Current | 
ba 
Lea 
aa, 


re Vpp. =5V 45% 
pee! 


V 
V Vop =5V +5% 
UL 
UL 








20 | -  | 
600 | Vit = 0.8V 
Vin = 2.0V 
2.4 *, lon = ~400 WA 
Output Low Voltage 0.40 *,loL.=2mA 
0.40 
2.4 


600 
200 
Vou | Output High Votage| 24 | — 
roa | 
Vout | Output High Votage| Vooos | 
roo | 
a | 
0 roa 
o 0 


Output High Voltage 









| Output Low Voltage | ~~ 

| Output High Voltage| 2.4 

_Vor___| Output Low Voltage | 

10 
0 


Output Capacitance 5 pF All outputs except: DO-D7, 
BMDO0-BMD7,BMP, OSC, and 
CPUCLK 

Output Capacitance 100 pF Outputs DO-D7,BMDO0-BMD7, 
and BMP 


Output Capacitance Pee 00 pe. Outputs OSC and CPUCLK 


Supply Current 200 mA 60 mA (typical); X1=32MHz, 
RRCLK=27MHz, 0°C, all out- 
puts open, Vpp=5V 


TABLE 7-1. DC CHARACTERISTICS 


0.40 











C 
C 


O 
O 


NOTES: 








Ta = 0°C (32°F) to 70°C (158°F), 
Vpp = +5V +5% 


* Output Voltages (all outputs except X2, 
CPUCLK, OSC, DO-D7), see fT 


** Output Voltages (CPUCLK and OSC only), 
seet 


*“*Output Voltages (DO-D7), see fT 
****Output Voltages (DO-D7, INT Logic 0) 
t Even under worst case AC transient switching 


conditions VoL = 0.8V shall not be exceeded on 
any output pin at any time. 
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8.0 AC OPERATING CHARACTERISTICS 


The following notes apply to all of the parameters 
presented in this section: 


1. All unit are in nanoseconds 

2. These timing relationships assume the maxi- 
mum capacitive loading for both inputs and out- 
puts, Vpp = 4.50 volts to 5.50 volts. 

3. Temperature = 0°C to 70°C. 

4. All timing is measured between 0.8 volts logic 


low and 2.0 volts logic high, unless otherwise 
noted. 


8.1 OSC AND CPUCLK TIMING 





FIGURE 8-1. TTL SOURCE X1 CLOCK INPUT 


FIGURE 8-2. OSC OUTPUT 
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CPUCLK 





FIGURE 8-3. CPUCLK OUTPUT 


po =f co xv Xt 
oot xe | xa 
1 jo UT xi xs 






The following table summarizes the relationship 
between the clock at X1 and the resultant outputs 
at OSC and CPUCLK. OSCDIV and CPUDIV are 
control bits in the RESET register that determine 
how the X1 clock is divided to produce OSC and 
CPUCLK. See the programming section for more 
information. 









21-52 11/19/91 ff 
| | 


AC OPERATING CHARACTERISTICS WD10C01 


No. [DESCRIPTION 
TTL source X1 rise or fall time (*1) 


OSC high or low when: (*2) 
X1/1 crystal (*3) 
X1/2 crystal (*3) 
X1/1 TTL source (*5) 
X1/2 TTL source (*4) 


CPUCLK high or low when: (*2) 
X1/2 crystal (*3) 
X1/3 crystal (*3) 
X1/4 crystal (*3) 
X1/6 crystal (*3) 
X1/2 TTL source (*4) 
X1/3 TTL source (*5) 
X1/4 TTL source (*4) 
X1/6 TTL source (*4) 


OSC cycle time when: 
X1/1 crystal (*3) 
X1/2 crystal (*3) 
X1/1 TTL source (*4) 
X1/2 TTL source (*4) 


CPUCLK cycle time when: 
X1/2 crystal (*3) 
X1/3 crystal (*3) 
X1/4 crystal (*3) 
X1/6 crystal (*3) 
X1/2 TTL source (* 
X1/3 TTL source (* 
( 





























































X1/4 TTL source (* 
X1/6 TTL source (* 


CPUCLK and OSC rise or fall time (*2) 
TABLE 8-1. OSC AND CPUCLK TIMING PARAMETERS 





4 
4 
4 
4 





NOTES: 
*1)Times are measured relative to Vin and *3)Assumes 33.3 MHz crystal across X1 and 
VIL. X2 for min times, 8.0 MHz crystal for max 
times. 
*2)High and low times are measured relative 
to the midpoints between VoL and Von. *4)Assumes 25.0 MHz TTL source to X1. 
Rise and fall times are measured between 
VOH and VoL. *5)Assumes 25.0 MHz TTL source to X1, 
50/50 duty cycle. 
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8.2 CPU INTERFACE TIMING 


EXTERNAL 
INTERFACE 
(inputs) 
input change 





FIGURE 8-4. MICROPROCESSOR RD* TIMING (RD* CONTROLLED) 


: z= : 


toy 
fe TSE RSA 


LX_DATA | VALID__> 


——| 
to4 


EXTERNAL 
INTERFACE 
(inputs) 
input change 





FIGURE 8-5. MICROPROCESSOR RD* TIMING (CS* CONTROLLED) 
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DB0-DB7 


EXTERNAL 
INTERFACE PREVIOUS DATA NEW DATA 


(Output) 


FIGURE 8-6. MICROPROCESSOR WR* TIMING (WR* CONTROLLED) 





ADDRESS VALID 





DBO-DB7 


EXTERNAL 
INTERFACE PREVIOUS DATA < NEW DATA 


(output) 





FIGURE 8-7. MICROPROCESSOR WR TIMING (CS* CONTROLLED) 
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ey 


t30 
tg 


EXTERNAL — 


INTERFACE 


OUTPUTS undefined state x reset state 





FIGURE 8-8. RESET TIMING 


DRVFLT or 


COMPLT fo S~"_ 


{39 


——— 





FIGURE 8-9. EXTERNALLY GENERATED INTERRUPT TIMING 
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DESCRIPTION, CCS 
address valid to RE or WE ns 
ons 

0 


No. | MAX | 
id to RE or WE (*3) i ns 
te: | REpulsewidth(*3) ——“‘~‘“*~*~* StS 
_teo | REorWEtoaddresschange("3) Cf ls 
tes | REtuetodatavalid('3) Cd ls 
tes | RE falsetodatahold (3) —i‘ | Os 

_inputportsetuptoREtue(1)("3) | 80 | ls 

) 


| 100 | ~ [ns 
Ea ae a 
tee | Wetalsetodatahold('s) ts 
WE false to output change (*2)(*3) --- | 80 | ns | 
jio0 [| ~ | ns 
p= | 150 | ns 
| i100 | ~ | ns 

ae Ee ae 
















RST pulse width 
RST true to stable outputs 
DRVFLT or COMPLT pulse width 


DRVEFLT or COMPLT high to INT low 
TABLE 8-2. CPU INTERFACE TIMING PARAMETERS 











NOTES: 


*1)Inputs are: PZO0-5, PYO-3 when defined as 
inputs, and AMDET when being used as a 
simple input pin. 


*2)Outputs are: PX0O-7, and PYO-3 when 
defined as outputs. 


*3)RE = RD or CS: 
WE =WRorCs 
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8.3. BUFFER INTERFACE TIMING 


(Data is coming out of the WD10C01) 
REQTIM=1 in RESET register. (REQA true when internal data register is full.) 


DATA UNDEFINED DATA VALID 


FIGURE 8-10. ASYNCHRONOUS MODE DATA BUS WRITE TIMING (1) 





REQTIM=0 in RESET register. (REQA true one bit time before internal data register is full. Note that the 
cycles overlap by one bit time.) 


DATA UNDEFINED DATA VALID 


FIGURE 8-11. ASYNCHRONOUS MODE DATA BUS READ TIMING (0) 
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(Data is going into the WD10C01) 
REQTIM=1 in RESET register. (REQA true when internal data register is empty.) 


146 


DATA UNDEFINED DATA VALID 





FIGURE 8-12. ASYNCHRONOUS MODE DATA BUS READ TIMING (1) 


REQTIM=0 in RESET register. (REQA true one bit time before internal data register is empty. Note that 
the cycles overlap by one bit time.) 


t44 
STE ITE ITT E CSET SCRE TTT ISDS TIE IN ES EEA INS 


t47 ‘48 
ee | <form 


DATA UNDEFINED DATA VALID 





FIGURE 8-13. ASYNCHRONOUS MODE DATA BUS WRITE TIMING (0) 
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‘No. | DESCRIPTION ‘MIN |MAX ——_—s[ UNITS 
| ty | DMA(REQA)cyoletime (1) | | Tye 

tur | ARCLKtuetoREQAtue | | 
| ty | ACKAfalsetoRRCLKtue | 


t43 REQA true to ACKA false: (*1) 














——- 










REQTIM=0 
REQTIM=1 


9" T cyc-t41-ta2 





ACKA active low 


ts | ACKAactivelow | 100 
tus | ACKAtnetodatavaid =| | 
(tus | ACKAfalsetodatahold =| | 
tay | datasetuptoACKA*fase | 85] 
i ra 

t49 









ACKA false to data hold 
tua | ACKA true to REQA false 


TABLE 8-3. BUFFER INTERFACE TIMING PARAMETERS | 





NOTES: 
“1)Teyc is the RRCLK cycle time used. 
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8.4 SERIAL DATA TIMING 


if synchronous 
(if sy ) fae tes 


61 


164 


Control 


INDEX or 
SECTOR or 
AMDET (if asynchronous) 





FIGURE 8-14. NRZ DATA INPUT TIMING 


{74 


> ea TD: 


= 
een 





FIGURE 8-15. NRZ DATA OUTPUT TIMING 
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No. |DESCRIPTION, 
3 
i 








NRZI setup to RRCLK high 
RRCLK high to NRZI hold 

RRCLK high to new control out (*3) 
AMDET setup to RRCLK high (*4) 
RRCLK high to AMDET hold (*4) 
asynchronous input width 


70 WRCLK high (*2) (*6) 
(*2) (*6) (*7) 


t71 WRCLK low (*2) (*6) 
("2) ("6) (7) 


t72 WRCLK low to NRZO change(*6) 
("6) (*7) 
173 NRZO setup to WRCLK high(*6) Trhi-9.5 
("6) (°7) Trhi-8.75 
WRCLK high to NRZO hold (*6) Trlo-9.5 
(*6) (*7) Tro-8.75 


175 RRCLK high to NRZO change le! 30 ns 


TABLE 8-4. SERIAL DATA TIMING PARAMETERS 


NOTES: *5)Asynchronous inputs are: INDEX, SEC- 
TOR, and AMDET when it is supplied from 
*1)High and low times measured relative to an asynchronous source. 
Vin and Vic. 
*6)Where the RRCLK input is driven from 
*2)Trlo and Trhi are the clock low and clock 0.4V (VIL) to 2.4V (Vin). 
high (respectively) for the RRCLK input 
used. Tcyc is RRCLK cycle time used. *7)The specification with reduced load 


Capacitance of 25 pF. 
*3)Control outputs are: SEQOUT, WG, RG, 
and AMENA. 


*4)When AMDET is supplied from a 
synchronous source. 
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A.0 WD10C01 PROGRAMMER’S BENCH REFERENCE (PBR) 
ADDR A.1 ADDRESS BIT TABLES 
The following is a set of bit tables. 


SRESET(00) 
7 CLKDIV 


SRESET 
SISR 





01 
2 






Y|L\i= 
== 


© 










ID3$4 
SRST 


SISR(01) AND SIMR(02) 
Read/Write 


7 GINT 
IDFULL 


SEQSTS(03) 
7 DATFLD 


ECCEN 









03 SEQSTS/PYC | RW rae 






PORTX 
PORTY 
PORT2Z/AMC R/W 


eee 
=\= 





OA 






= 
= 


SEQCTL 
START 
LOOP 
ECCCTL 
SECCNT 
ECCP 
ECCS 
SPORT 
Reserved 


= 
D 













OC 






OE 
OF 
10 
11 

12 
13 
, 
15 

















Reserved 


ff 


Y)QiDiz/=\z 
=\|=/\= = 


Reserved 









: 


17 SKIP 






D 
= 


D1 
D2 W 
ID3 R/W 


D4 
IDS 





WAIT | 


AMDET 
SEQOUT 


> 


ee ee ee ee ee ee eee Ce eee Ce eo © 
mio 1|O /}W © | 












~~ 





= 


1F ID7 
TRUE = 1 FORALL BITS 








11/19/91 21-63 


aN 


WD10C01 


WD10C01 PROGRAMMER’S BENCH REFERENCE (PBR) 










Bit | Write 


7 Lees eau ea 





Or | POUR, 


CSERR(04) 
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FAIL 
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Read/Write 
BUFF 
NOXFER 
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5 











a 





21-64 


11/19/91 ff 


WD10C01 PROGRAMMER’S BENCH REFERENCE (PBR) WD10C01 
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CRCSET 
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1 DISPTY 
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B.0 RESET CONDITIONS 


RESET CONDITIONS 


The following list defines what is reset when RST __ The following outputs are reset to zero: 


is asserted on the WD10C01, or the CPU sets the °¢ PX0-7 
internal reset bit (SRST in SRESET register): ° SEQOUT 
¢ SRST bit in SRESET is left set, and must be » AMENA 
cleared by the CPU to take the WD10C01 out 
of the reset state * RG 
¢ interrupts are disabled ° WG 
* PYO-3 are set to input * NRZO 
¢ BMDO-7,P are disabled * REQA 
* OSC is set to X1/2 The following error status bits are reset to zero: 
¢ CPUCLK is set to X1/6 ¢ IDERR 
* command sequencer stops ¢ PTYERR 


The following CPU registers are reset to zero: 
e PORT X 


¢ PORT Y CONFIGURATION 

¢ SECTOR COUNTER 

¢ INTERRUPT MASK REGISTER 
SRESET REGISTER (except SRST) 


¢ ECCP except SYNCCRC and SYNCECC, 
which are initialized to one’s 


e ECCS 
¢ SPORT 
KILL and RGERLY bits in SEQCTL register 
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C.0 CRYSTAL OSCILLATOR APPLICATIONS 


ee ee 


180 100 


For applications that use the internal oscillator 
capability of the WD10C01, a series resonant 
crystal must be used. This crystal must meet the 
following internal specifications: 


CS = 7 pf MAX 
RS = 30 ohms MAX 








The oscillator also requires bypass capacitors, as 
shown in the following diagram:The following 
table lists values for C1 and C2 for several typical 
crystal frequencies. The capacitor tolerances are 
+10%. Values for intermediate frequencies (not 
listed in the table) may be extrapolated. 


Pin 37. [x1] 


Crystal 


Pin 38 [x2] 





FIGURE C-1. OSCILLATOR WITH CAPACITORS 
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D.0 PIN/SIGNAL SUMMARY 


_PIN| SIGNAL | VO | FUNCTION. 












BMD7 V0 | Buffer 
BMD6 Buffer 
BMD5 VO | Buffer 


6 | pmp2 | vO | Buffer 
8 | BMDO | VO | Butfer 


Ground 
CPU Interface 
CPU Interface 
O | CPU Interface 
I/O | CPU Interface 
CPU Interface 
CPU Interface 
CPU Interface 
CPU Interface 
CPU Interface 
CPU Interface 
CPU Interface 
CPU Interface 
CPU Interface 
CPU Interface 
CPU Interface 
CPU Interface 
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voD 
INT CPU Interface 
Disk Control 
Disk Contro| 
Disk Data 
Disk Data 
Disk Data 
CPU Interface 
Disk Control 
Disk Control 





PIN/SIGNAL SUMMARY 






_PIN| SIGNAL | VO | FUNCTION 
_86_| CPUCLK | O | CPUInterface | 
37 | xt 1 | cru interface _ | 
X2 CPU Interface 

39 | Pz5 | I | Disk Control 
| 40 | pz4 | 1 _| DiskControl 
41 | pz3 | || DiskContro 










































42 | pz2 | I | Disk Control 
43 | vss | |__| Ground 

44 | Pz1 |b | DiskConto 
45 | Pzo | 1 _|_ Disk Control 

PY3 TO | Disk Control 
47. | Py2 | 10 | Disk Control 
4a | Pyi | 140. Disk Control 
49 | PYo | 1,0 | Disk Control 
50 | PX7 | Oo | Disk Control 
81 | PX6 | O_| Disk Control 

| 52 | PX5 | O_| Disk Control 

| 53 | Pxa fo | Disk Control 
54 | Pxs =| oO | Disk Control 

PX2 0 | Disk Control 
56 | PxX1 | Oo | Disk Control 
57 | PXO =| Oo | Disk Control 
58 | wa | © | Disk Data 

59 | RG | O | Disk Data 

60 | VOD | 1 | +5 Volts 
fer | Rst™  |1 | CPU Interface 
_62_| WRCLK | © | Disk Data 

63 | NRZO__| O | Disk Data 

64 | RRCLK | 1 | Disk Data 

65 | NRZi_| I _| Disk Data 

66 | REQA | O | Buffer 

ACKA Pat Buffer 

68 | DBP | VO | Butter 
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E.0Q DIFFERENCES BETWEEN WD10C00 AND WD10C01 


E.1 ERROR CORRECTION AND 
DETECTION 


The computer-generated-code ECC in WD10C00 
was replaced with the Reed-Solomon ECC in 
WD10C01. Six registers (ECC[0:5]) which define 
the masks for ECC polynomials in WD10C00 
were taken out. The new ECCP, ECCS, SPORT 
registers facilitate the configuration parameters, 
operation status and the syndrome access for the 
new RS encoder/decoder. 


E.2 SRESET REGISTER 


The contro! bits IDCHK, DCHK, ECCSIZ bits of 
the WD10C00 are removed. By default, data field 
is covered by RS-ECC, and ID Bield | Is covered by 
CCITT-CRC with g(x)= X'° + X!? 4 X° 4.1. 


E.3 ECCCTL REGISTER 


The ECCINL, ECCSHT, ECCINM bits of the 
WD10C00 are removed. The control bit ECCSET 
is renamed to CRCSET, bit ECCNIT is renamed 
to CRCNIT. These bits affect only the CRC shift 
registers, the RS-ECC shift registers are be 
default reset to zero. The control bit DISCHK of 
WD10C00 is changed into IGNERR. Its function is 
still the same. 


E.4 TIMING 


The timing ta7 (data setup time on the BMD bus 
before ACKA goes inactive) is changed from 30 
ns to 35 ns; t7o, t71, t72, t73 and t74 have additional 


specifications with reduced loading capacitance of 
25 pF. 


E5 PINNAME 


The name of the microprocessor data bus and the 
DMA data bus are changed to reflect the name on 
the circuit diagrams. The pin order and the func- 
tions are exactly the same as before. 


DBP 












E.6 PARITY ERROR HANDLING 


WD10C00 will latch the parity error condition into 
the SEQCTL register and the operation will con- 
tinue normally. WD10C01 will stop at the end of 
the current CS instruction if the FAIL bit is set to 
one. The WG output is also deasserted. 


E.7 SEQCTL REGISTER 


Bit 6 and bit 0 in the SEQCTL register are unused 
in the WD10C00 and in the WD10C01. These bits 
are read-only type and are set to one in the 
WD10C00; in the WD10C01, these bits are set to 
zero. 
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